当前位置: 首页 > 图文教程 > 数据库 > Oracle > 使用Instr()与decode()进行多条件组合查询

Oracle
教你应对Oracle检索数据的一致性以及回滚数据
美国家庭影院频道成功实施Oracle套件
Oracle学习教程
利用oracle外部表查看报警信息
合理设置临时表空间确保Oracle数据库正常运行
Oracle数据库如何处理临时数据?
ORACLE报警日志如何查看?
Oracle教程:如误添加数据文件如何删
Oracle10gR2上遇到了Mutex竞争的问题
Oracle教程:讲述表与表见得连接
Oracle教程:修改初始化参数
Oracle教程:工具kfod的使用
Oracle数据库是如何进制转换的
两种方法来组织Oracle数据库中的数据
Oracle教程:如何将数据文件移到新区
三要素助你在Oracle中创建索引
如何将各种数据库连接起来?
Oracle数据库导入外部数据如何实现
Oracle数据库的输出方法调试
Oracle教程:数据的复制

Oracle 中的 使用Instr()与decode()进行多条件组合查询


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-31   浏览: 83 ::
收藏到网摘: n/a

    系统中遇到了要处理多条件组合查询的情况,好比说有4个独立的条件,那么组合出的查询条件便有24种,不可能写24条Sql语句再分别指定给24种组合情况吧,条件数再多点呢,人都会搞疯的。。。。于是我求助于高手,获得了使用instr()和decode()函数的实现方法。

    下面先说明一下instr()的功能和语法:(函数的语法是从http://www.techonthenet.com/oracle/functions/index.htm处得到的,相当清晰明了:)

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] )