加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

我经常看到快速全索引扫描“在野外”,但都是可能的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读