instr like
来源:互联网 发布:炉石传说mac版2017 编辑:程序博客网 时间:2024/05/17 07:39
ORACLE中Like与Instr模糊查询性能大比拼
instr(title,'手册')>0 相当于 title like '%手册%'
instr(title,'手册')=1 相当于 title like '手册%'
instr(title,'手册')=0 相当于 title not like '%手册%'
t表中将近有1100万数据,很多时候,我们要进行字符串匹配,在SQL语句中,我们通常使用like来达到我们搜索的目标。但经过实际测试发现,like的效率与instr函数差别相当大。下面是一些测试结果:
SQL> set timing on
SQL> select count(*) from t where instr(title,'手册')>0;
COUNT(*)
----------
65881
Elapsed: 00:00:11.04
SQL> select count(*) from t where title like '%手册%';
COUNT(*)
----------
65881
Elapsed: 00:00:31.47
SQL> select count(*) from t where instr(title,'手册')=0;
COUNT(*)
----------
11554580
Elapsed: 00:00:11.31
SQL> select count(*) from t where title not like '%手册%';
COUNT(*)
----------
11554580
另外,我在结另外一个2亿多的表,使用8个并行,使用like查询很久都不出来结果,但使用instr,4分钟即完成查找,性能是相当的好。这些小技巧用好,工作效率提高不少。通过上面的测试说明,ORACLE内建的一些函数,是经过相当程度的优化的。
instr(title,’aaa’)>0 相当于like
instr(title,’aaa’)=0 相当于not like
特殊用法:
select id, name from users where instr('101914, 104703', id) > 0;
它等价于
select id, name from users where id = 101914 or id = 104703;
- instr like
- like vs instr效率
- instr() v.s. like
- Mysql 使用instr代替like
- oracle中like和instr
- 模糊查询Like与Instr
- oralce instr与 like 比较
- instr和like效率对比
- Mysql 使用instr代替like
- Oracle中instr与like
- oracle instr函数(oracle 用instr 来代替 like)
- oracle instr函数(oracle 用instr 来代替 like)
- oracle instr函数(oracle 用instr 来代替 like)
- oracle instr函数(oracle 用instr 来代替 like)
- oracle instr函数(oracle 用instr 来代替 like)
- oracle instr函数(oracle 用instr 来代替 like)
- racle instr函数(oracle 用instr 来代替 like)
- oracle like 和instr的效率差别
- 一些图像处理的数据集
- Fifth-自动旋转和自动调整大小
- 计算机视觉、机器学习相关领域论文和源代码大集合--持续更新……
- C#编程基础 实验(10) (5)
- MaterialDesign之Dialog
- instr like
- Search in Rotated Sorted Array-旋转数组的查找
- C++ std::bind思考
- c++ curl下载和上传数据——c++(学习一)
- Android签名简介
- STL
- Eclipse引用外部project android library
- Linux make
- iOS dispatch_group的使用