新参者:) 2023-06-13 10:45 采纳率: 75%
浏览 25
已结题

oracle复核索引问题

都说oracle复合索引必须遵循最左原则,查询条件里要包含索引的第一列,那为什么会出现以下情况呢?

img

img

img

还有一个类似的,复合索引右边的条件走了索引,反而左边没走索引,是优化器做了选择还是?

img

img

  • 写回答

1条回答 默认 最新

  • AllenGd 大数据领域优质创作者 2023-06-14 15:07
    关注

    虽然复合索引遵循最左原则,但是在某些情况下,查询条件中不包含索引的第一列也可以使用复合索引。
    因为Oracle优化器会根据查询条件的具体情况来选择最优的索引。
    举个例子:如果复合索引的第一列是性别,第二列是年龄,查询条件中只包含年龄,那么优化器可能会选择使用该复合索引,因为该索引可以帮助优化器快速定位到符合年龄条件的数据,而性别列的值对查询结果的筛选并没有太大的影响。
    同样的道理,如果复合索引右边的条件走了索引,而左边的条件没有走索引,因为优化器认为这样可以更快地定位到符合条件的数据。这种情况下,优化器可能会使用索引的部分列来加速查询,而不是使用全索引。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月6日
  • 已采纳回答 6月28日
  • 创建了问题 6月13日

悬赏问题

  • ¥100 有偿寻云闪付SDK转URL技术
  • ¥30 基于信创PC发布的QT应用如何跨用户启动后输入中文
  • ¥20 非root手机,如何精准控制手机流量消耗的大小,如20M
  • ¥15 远程安装一下vasp
  • ¥15 自己做的代码上传图片时,报错
  • ¥15 Lingo线性规划模型怎么搭建
  • ¥15 关于#python#的问题,请各位专家解答!区间型正向化
  • ¥15 unity从3D升级到urp管线,打包ab包后,材质全部变紫色
  • ¥50 comsol温度场仿真无法模拟微米级激光光斑
  • ¥15 上传图片时提交的存储类型