深入理解Oracle索引(9):不要过分依赖 HINT

本文通过官方文档和测试案例深入探讨了在Oracle中过度依赖HINT的潜在风险。当指定的HINT所指的索引无效时,CBO会选择成本最低的其他索引,甚至可能会选择不适用于当前查询的Bitmap索引,而非进行全表扫描。
摘要由CSDN通过智能技术生成
    多应用开发人员、特别是技术大拿、喜欢通过 HINT 强制Oracle CBO按自己的意志选择执行计划
   Rocky 窃以为、这种策略在某种程度上其实是把双刃剑
   使用 Hint 指定 Index 的时候需要慎重、如果不合适或者无效、可能画蛇添足、效率更低
   

   摘自官方文档:


If the INDEX hint specifies no indexes, then the optimizer considers the cost of a scan on each available index on the table and 
then performs the index scan with the lowest cost. The database can also choose to scan multiple indexes and merge the results, 
if such an access path has the lowest cost. The optimizer does not consider a full table scan.


   如果我们使用 HINT 指定了一个无效的 Index、CBO 会扫描表中所有可以使用的 Index
   然后选择 cost 最小的 Index 或者复合索引、而不会选择全表扫描
   
   测试:
   
   ① 创建一个表、

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值