Oracle 模糊查询优化
2013-08-06 19:20
267 查看
模糊查询是数据库查询中经常用到的,一般常用的格式如下:
(1)字段 like '%关键字%'
字段包含"关键字“的记录 即使在目标字段建立索引也不会走索引,速度最慢
(2)字段 like '关键字%' 字段以"关键字"开始的记录 可以使用到在目标字段建立的升序索引
(3)字段 like '%关键字' 字段以"关键字“结束的记录 可以使用到目标字段建立的降序索引
对于无法使用索引的 '%关键字%' 模式,有没有办法优化呢,答案是肯定的,
在ORacle中提供了instr(strSource,strTarget)函数,比使用'%关键字%'的模式效率高很多。
instr函数说明:
INSTR
(源字符串, 目标字符串, 起始位置, 匹配序号)
在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始
到字符的结尾就结束。
语法如下:
instr( string1, string2 [, start_position [, nth_appearance ] ] )
参数分析:
string1
源字符串,要在此字符串中查找。
string2
要在string1中查找的字符串.
start_position
代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。
nth_appearance
代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。
注意:
如果String2在String1中没有找到,instr函数返回0.
示例:
SELECT instr('syranmo','s') FROM dual; -- 返回 1
SELECT instr('syranmo','ra') FROM dual; -- 返回 3
1 SELECT instr('syran mo','a',1,2) FROM dual; -- 返回 0
模糊查询优化:
了解了instr函数的用法,优化就变得简单了,例如 %关键字% 等同于 instr(字段,'关键字')>0
经过我的简单测试,instr函数比like %关键字% 大概快一倍。
(1)字段 like '%关键字%'
字段包含"关键字“的记录 即使在目标字段建立索引也不会走索引,速度最慢
(2)字段 like '关键字%' 字段以"关键字"开始的记录 可以使用到在目标字段建立的升序索引
(3)字段 like '%关键字' 字段以"关键字“结束的记录 可以使用到目标字段建立的降序索引
对于无法使用索引的 '%关键字%' 模式,有没有办法优化呢,答案是肯定的,
在ORacle中提供了instr(strSource,strTarget)函数,比使用'%关键字%'的模式效率高很多。
instr函数说明:
INSTR
(源字符串, 目标字符串, 起始位置, 匹配序号)
在Oracle/PLSQL中,instr函数返回要截取的字符串在源字符串中的位置。只检索一次,就是说从字符的开始
到字符的结尾就结束。
语法如下:
instr( string1, string2 [, start_position [, nth_appearance ] ] )
参数分析:
string1
源字符串,要在此字符串中查找。
string2
要在string1中查找的字符串.
start_position
代表string1 的哪个位置开始查找。此参数可选,如果省略默认为1. 字符串索引从1开始。如果此参数为正,从左到右开始检索,如果此参数为负,从右到左检索,返回要查找的字符串在源字符串中的开始索引。
nth_appearance
代表要查找第几次出现的string2. 此参数可选,如果省略,默认为 1.如果为负数系统会报错。
注意:
如果String2在String1中没有找到,instr函数返回0.
示例:
SELECT instr('syranmo','s') FROM dual; -- 返回 1
SELECT instr('syranmo','ra') FROM dual; -- 返回 3
1 SELECT instr('syran mo','a',1,2) FROM dual; -- 返回 0
模糊查询优化:
了解了instr函数的用法,优化就变得简单了,例如 %关键字% 等同于 instr(字段,'关键字')>0
经过我的简单测试,instr函数比like %关键字% 大概快一倍。
相关文章推荐
- Oracle大字段(clob)模糊查询优化方法
- Oracle 模糊查询优化
- ORACLE模糊查询优化浅谈
- oracle模糊查询优化
- oracle like模糊查询的优化测试
- Oracle 模糊查询优化
- oracle模糊查询优化
- ORACLE多表查询优化
- oracle 模糊查询传参
- ORACLE多表查询优化
- Oracle查询性能优化
- like模糊查询的优化
- Oracle 百万行数据查询优化
- oracle 模糊查询 like
- Oracle查询优化
- Oracle查询优化-使用字符串
- Oracle 10G 新特性——ADDM和查询优化建议器
- 【书评:Oracle查询优化改写】第二章
- oracle 时间date 类型 like模糊查询例子
- ORACLE 性能优化-查询数据库慢SQL(其实还是awr和ash报告更方便~)