奇趣技术网 收藏本站
设为主页
商务合作
首页 新闻中心 行业动态 软件新闻 安全资讯 病毒预警 漏洞发布 操作系统 Dos Win9x Win2000 WinXP Win2003 WinVista Linux Unix
数据库 DB2 Access MSSQL MySQL Oracle Sybase 编程技术 ASP PHP JSP CGI/Perl XML .Net C/C++/C# VB VC Delphi Java 汇编
安全技术 安全教学 工具介绍 漏洞利用 病毒防范 入侵检测 防火墙 安全防范 汉化破解 攻击实例 加密解密 技术论坛
中华网络安全联盟 >> 数据库 >> Oracle >> 使用Oracle的Instr()与decode()函数进行多条件组合查询
数据库
Access
SQL Server
MySQL
DB2
Oracle
Sybase
  • Linux下安装支持ssl连

  • 在同一台机运行多个My

  • 我的MYSQL安装笔记拿出

  • 写了个简单的数据库自

  • Oracle 10g中新型层次

  • ORACLE回滚段管理(下

  • ORACLE回滚段管理(上

  • Oracle大文本在ASP中存

  •   
    使用Oracle的Instr()与decode()函数进行多条件组合查询
    字体:

    中华网络安全联盟    作者:佚名    来源:网络转载    时间:2006-3-23

    系统中遇到了要处理多条件组合查询的情况,使用instr()和decode()函数的实现方法。

    下面先说明一下instr()的功能和语法:(函数的语法是从处得到的,相当清晰明了:)

    In Oracle/PLSQL, the instr function returns the location of a substring in a string.

    The syntax for the instr function is:

    instr (string1, string2, [start_position], [nth_appearance])

    string1 is the string to search.

    string2 is the substring to search for in string1.

    start_position is the position in string1 where the search will start.  This argument is optional.  If omitted, it defaults to 1.  The first position in the string is 1.  If the start_position is negative, the function counts back start_position number of characters from the end of string1 and then searches towards the beginning of string1.

    nth_appearance is the nth appearance of string2.  This is optional.  If omiited, it defaults to 1.

    再说明一下decode()的功能和语法:

    In Oracle/PLSQL, the decode function has the functionality of an IF-THEN-ELSE statement.

    The syntax for the decode function is:

    decode ( expression , search , result [, search , result]... [, default] )

    expression is the value to compare.

    search is the value that is compared against expression.

    result is the value returned, if expression is equal to search.

    default is optional.  If no matches are found, the decode will return default.  If default is omitted, then the decode statement will return null (if no matches are found).

    综合使用得到的SQL语句如下:

    select e.到达日期,

    e.角色名,

    d.单据标题,

    d.单据编号,

    e.节点编号,

    e.处理动作,

    e.处理日期,

    b.流程实例编号

    from gzl_流程类型a,

    gzl_流程实例b,

    gzl_流程定义c,

    dj_单据    d,

    gzl_流程流转状态 e

    where a.流程类型编号 = c.流程类型编号 and e.处理标记 = '是'

    and   e.用户id = 'tetdmis' and b.流程定义编号 = c.流程定义编号    

    and b.活动编号 = d.单据编号 and c.流程定义编号 = b.流程定义编号

    and  e.流程实例编号 = b.流程实例编号

    and instr(decode(:流程类型条件, '-1', a.流程类型编号, :流程类型条件), a.流程类型编号) > 0

    and (to_char(e.处理日期, 'yyyy-mm-dd') between :开始日期 and :结束日期)

    and instr(decode(:节点名称条件, '-1', e.处理动作, :节点名称条件),

    e.处理动作) > 0



    字体:
     
    设为主页 收藏本站 联系我们 友情连接 商务合作 网友留言
    Copyright©2006-2008 中华网络安全联盟 All rights reserved.