tupaiopiao 2022-07-26 10:34 采纳率: 80.3%
浏览 46
已结题

oracle查询扫描全表和走索引

一个是select CLS_DATE where CLS_DATE =X走了索引,一个是select CLS_DATE ,b,c where CLS_DATE =x 走了全表扫描 对字段CLS_DATE 建了索引 这是为什么呢
不是,一个是查询字段为索引字段,一个是除了查询索引字段外还有其他字段,前者走了索引,后者走了全表

img

img

  • 写回答

4条回答 默认 最新

  • riven2011 2022-07-29 16:08
    关注

    index fast full scan:快速索引扫描,扫描整个索引段,多块读
    index range scan:索引范围扫描,扫描一部分索引段,单块读
    table full scan:全表扫描,扫描整个表段,多块读
    当CBO评估索引范围扫描耗费不是最优情况下,会优先选择全表扫描(包含快速索引扫描)
    一般情况索引存储小于表段,在索引段满足sql情况下,优先选择索引快速扫描

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 9月15日
  • 已采纳回答 9月7日
  • 修改了问题 7月26日
  • 创建了问题 7月26日