SQL / Oracle:可以使用多个列的索引
发布时间:2020-12-12 16:15:19 所属栏目:MsSql教程 来源:网络整理
导读:如果我按列(A,B,C)创建索引,我的理解是数据库将能够使用它,即使我只搜索(A)或(A和B)或( A和B和C),但如果仅在(B)或(C),或(B和C)上搜索,则不能.它是否正确? 解决方法 实际上,当谓词放在索引的非引导列上时,Oracle可以使用三种基于索引的访问方法. i)索引跳过扫
如果我按列(A,B,C)创建索引,我的理解是数据库将能够使用它,即使我只搜索(A)或(A和B)或( A和B和C),但如果仅在(B)或(C),或(B和C)上搜索,则不能.它是否正确?
解决方法实际上,当谓词放在索引的非引导列上时,Oracle可以使用三种基于索引的访问方法.i)索引跳过扫描:http://download.oracle.com/docs/cd/B19306_01/server.102/b14211/optimops.htm#PFGRF10105 ii)快速全索引扫描:http://download.oracle.com/docs/cd/B19306_01/server.102/b14211/optimops.htm#i52044 iii)索引全扫描:http://download.oracle.com/docs/cd/B19306_01/server.102/b14211/optimops.htm#i82107 我经常看到快速全索引扫描“在野外”,但都是可能的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- SQLSERVER数据审计
- 【SqlServer】Microsoft SQL Server 2008技术内幕:T-SQL查询
- sqlserver四舍五入使用round函数及cast和convert函数
- 如何在sqlserver中写存储过程
- DBCC大全集之(适用版本MS SQLServer 2008 R2)----DBCC FR
- sqlserver呼叫中心保留通话时长最长的记录
- SQLServer的sql语句中有非法的空格问题
- sqlserver在企业管理器中设置datetime默认值为当前时间
- MSSQL2005 INSERT,UPDATE,DELETE 之OUTPUT子句使用实例
- 在dplyr连接中忽略大小写敏感性