嗷呜的善泽融 2022-05-13 09:24 采纳率: 70%
浏览 70
已结题

oracle hints 优化器 /*+full(t)*/在测试环境生效,使用了全表扫描;生产环境不生效,仍然走了索引

背景:
测试环境:oracle 19c;
生产环境:oracle 11g;
bonddesc表在生产环境和测试环境是一样的,数据量以及索引都是一致的
现象:
最近想做一下sql性能优化,但是很奇怪的现象是,同一条sql:SELECT /+full(t)/ * FROM bonddesc t WHERE t.s_info_windcode = '166661.SH'
在测试环境测试的时候是可以全表扫描;而生产环境仍然走的是索引,就很奇怪,有牛人知道有什么情况会导致上面这种现象

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-05-13 23:01
    关注

    因为CBO觉得你加的这个hint太离谱了,消耗成本过高,因此它自行选择了成本更低的方式。
    你可以先尝试一下更新这个表的统计信息再试,如果依旧没有full,说明可能的确不适合用full
    另外,不同版本的数据库,CBO算法不完全一样

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

报告相同问题?

问题事件

  • 系统已结题 5月24日
  • 已采纳回答 5月16日
  • 创建了问题 5月13日

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line