oracle like模糊查询不能走索引详解数据库
2023-06-13 09:20:12 时间
这里要纠正一个网上很多教程说的模糊匹配不能走索引的说法,因为在看《收获,不止SQL优化》一书,里面举例说到了,并且自己也跟着例子实践了一下,确实like一些特殊情况也是可以走索引的
例子来自《收获,不止SQL优化》一书,实践准备:
//建表,注意要非空数据 drop table t purge; create table t as select * from dba_objects where object_id is not null; select * from t; //更新数据并建索引,用来测试 update t set object_id=rownum; update t set object_name=AAALJB where object_id=8; update t set object_name=LJBAAA where object_id=10; create index idx_object_name on t(object_name);
用set autotrace on用来打印执行计划,这里注意了,用LJB%去模糊匹配,然后观察执行计划,发现是索引范围扫描INDEX RANGE SCAN 的,因为去匹配LJB开头的数据,索引是可以范围查询并匹配到,所以是能走范围索引扫描的,所以网上的说法是不全面的
SQL set autotrace on SQL select object_id,object_name from t where object_name like LJB%; OBJECT_ID ---------- OBJECT_NAME -------------------------------------------------------------------------------- LJBAAA
---------------------------------------------------------- Plan hash value: 1138138579 -------------------------------------------------------------------------------- --------------- | Id | Operation | Name | Rows | Bytes | Cost (%C PU)| Time | -------------------------------------------------------------------------------- --------------- | 0 | SELECT STATEMENT | | 1 | 79 | 4 (0)| 00:00:01 | | 1 | TABLE ACCESS BY INDEX ROWID| T | 1 | 79 | 4 (0)| 00:00:01 | |* 2 | INDEX RANGE SCAN | IDX_OBJECT_NAME | 1 | | 3 (0)| 00:00:01 | -------------------------------------------------------------------------------- ---------------
Predicate Information (identified by operation id): --------------------------------------------------- 2 - access("OBJECT_NAME" LIKE LJB%) filter("OBJECT_NAME" LIKE LJB%) Note ----- - dynamic sampling used for this statement (level=2)
上面列举了,能走索引的例子,然后改一下用%LJB去匹配,看看能不能走索引?
SQL set autotrace on SQL select object_id,object_name from t where object_name like %LJB; OBJECT_ID ---------- OBJECT_NAME -------------------------------------------------------------------------------- AAALJB
---------------------------------------------------------- Plan hash value: 1601196873 -------------------------------------------------------------------------- | Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time | -------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 12 | 948 | 288 (1)| 00:00:04 | |* 1 | TABLE ACCESS FULL| T | 12 | 948 | 288 (1)| 00:00:04 | -------------------------------------------------------------------------- Predicate Information (identified by operation id): --------------------------------------------------- 1 - filter("OBJECT_NAME" IS NOT NULL AND "OBJECT_NAME" LIKE %LJB) Note ----- - dynamic sampling used for this statement (level=2)
SQL
例子可以看出是全表扫描的,不走索引,因为%LJB这种匹配,索引不能确认唯一性,同样的%LJB%去匹配也是不走索引的
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/5063.html
相关文章
- 表空间最佳Oracle数据库UNDO表空间管理实践(oracle的undo)
- Oracle缓存提高数据库性能的奥妙 (oracle缓存命中)
- Oracle安装目录查找:寻找未知之路(查找oracle安装目录)
- Oracle自动生成唯一编号功能简介(oracle自动编号)
- 使用Oracle触发器,提高数据库性能(oracle触发器类型)
- 探讨 Oracle 数据库触发器类型(oracle触发器类型)
- Oracle数据库中的内置函数使用(oracle的内置函数)
- 深入浅出Oracle:系统解读数据库基础知识(深入浅出oracle)
- Oracle 监控工具简介:使用自带监控工具轻松监控数据库。(oracle自带监控工具)
- Oracle官方公布最新产品报价清单,一览众多方案与价格(oracle官方报价)
- Oracle:活用常量提升效率(oracle常量)
- 解决oracle数据库卡顿问题的有效技巧(oracle数据库卡)
- 埃里森之光:Oracle 企业数据库的真正强大之处(oracle 埃里森)
- 降低数据库损失Oracle冗余级别最佳实践(oracle冗余级别)
- Oracle共享存储带来的挑战(oracle共享存在问题)
- Oracle优化减小日志文件尺寸(oracle减小日志文件)
- 结构使用C语言从Oracle数据库获取表结构(c oracle 获取表)
- 利用CMD安全配置Oracle数据库(cmd设置oracle)
- 库今日Oracle数据库发展前景一片光明(oracle今天数据)
- Oracle字符集更改为GBK(oracle修改为gbk)
- Oracle中查询结果集获取智慧数据的新方法(oracle中查询结果集)
- RS取值,Oracle数据库精彩探索(oracle rs取值)