Oracle 模糊查询优化
来源:互联网 发布:my card萌卡mac 编辑:程序博客网 时间:2024/04/29 03:55
模糊查询是数据库查询中经常用到的,一般常用的格式如下:
(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
- Oracle 模糊查询优化
- Oracle 模糊查询优化
- Oracle 模糊查询优化
- oracle模糊查询优化
- Oracle模糊查询优化
- ORACLE模糊查询优化浅谈
- oracle like模糊查询的优化测试
- 模糊查询的优化
- 模糊查询的优化
- Oracle大字段(clob)模糊查询优化方法
- ORACLE中的模糊查询
- oracle 模糊查询问题
- Oracle 模糊查询
- Oracle 模糊查询
- oracle like模糊查询
- oracle 模糊查询
- Oracle 模糊查询
- Oracle的模糊查询
- C语言学习笔记11--位运算
- Spring MVC和Struts2的比较
- C# PropertyGrid控件应用心得
- javascript捕获页面窗口关闭事件
- 搭建XMPP协议,实现自主推送消息到手机
- Oracle 模糊查询优化
- Qt下的第一个ACE程序
- java安卓应用开发
- OCP-1Z0-051 第155题 集合操作UNOIN
- 从开始到现在耗费的时间
- 如果我不能带给你平静的喜乐
- (黑马程序员)学习笔记,File对象
- 如何编出健壮的代码 java编程30条规则
- 态度和能力