我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle如何通过注释改变执行计划

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle如何通过注释改变执行计划

小编给大家分享一下Oracle如何通过注释改变执行计划,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

Oracle 通过注释改变执行计划

一:问题现象

T_XXX表同步延时1小时,其它表同步速度正常;

主要慢在同步时的一个delete T_XXX语句上,单条执行耗时12秒;

 

二:问题原因

T_XXX表存在唯一性索引,理论上速度很快;

查看T_XXX表存在delete行级触发器,查看触发器逻辑,发现触发器内一个update语句特别慢;

UPDATE CHENJCH.T_CHENJCH_RISK ..where  RISK_ID ....

查看执行计划,update语句走全表扫描,速度很慢,通过hint强制走主键索引,速度特别快;

为什么执行计划不走主键?

查看T_CHENJCH_RISK表统计信息显示表有0行数据,但是实际上有200万行数据;

由于数据同步时T_CHENJCH_RISK表存在大量的delete/update/insert操作,上次收集统计信息时正好这个表里没有数据,但是经过几天的数据同步后,表里的数据量发生了很大变化,统计信息也不是实时进行收集,最终导致生成较差的执行计划;

解决方案:

尝试删除T_CHENJCH_RISK表统计信息,让数据库通过动态取样实时的收据信息,但是执行计划没有变,还是走全表扫描,速度没有提高;

begin

  dbms_stats.delete_table_stats(ownname => 'CHENJCH', tabname => 'T_CHENJCH_RISK');

end;

尝试重新收集T_CHENJCH_RISK表统计信息,让数据库通过动态取样实时的收据信息,但是执行计划没有变,还是走全表扫描,速度没有提高;

begin

  DBMS_STATS.GATHER_TABLE_STATS('CHENJCH',

                                'T_CHENJCH_RISK',

                                estimate_percent => 100,

                                method_opt       => 'FOR ALL INDEXED COLUMNS',

                                degree           => 6,

                                CASCADE          => TRUE);

end;

为什么执行计划没有变?

(数据库版本Oracle 12.2.0.1.0)

因为SQL语句存在绑定变量,SQL文本没有变,导致执行计划也没有发生变化;

通过对表T_CHENJCH_RISK添加和删除注释,可以让数据库重新生成执行计划;

comment on column CHENJCH.T_CHENJCH_RISK.RISK_ID   is  'PK_T_CHENJCH_RISK';

comment on column CHENJCH.T_CHENJCH_RISK.RISK_ID   is  '';

查看新生成的执行计划,T_CHENJCH_RISK已经开始走主键索引了,速度有明显提升;

以上是“Oracle如何通过注释改变执行计划”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle如何通过注释改变执行计划

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何利用Oracle变量优化存储过程执行计划

优化存储过程执行计划可以通过使用Oracle变量来减少重复计算和提高查询性能。以下是一些利用Oracle变量优化存储过程执行计划的方法:使用变量存储查询结果:在存储过程中使用变量来存储查询结果,可以避免重复查询数据库,提高查询性能。例如,将
如何利用Oracle变量优化存储过程执行计划
2024-08-24

Spring Task如何动态修改任务执行计划cron

小编给大家分享一下Spring Task如何动态修改任务执行计划cron,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Spring Task 动态修改任务执行计划
2023-06-25

如何在ODBC连接Oracle时优化SQL执行计划

要在ODBC连接Oracle时优化SQL执行计划,可以考虑以下几点:使用索引:确保在查询中使用了适当的索引,可以加快查询的执行速度。统计信息:确保表和索引的统计信息是最新的,可以通过收集统计信息来帮助优化执行计划。使用HINT提示:根据实际
如何在ODBC连接Oracle时优化SQL执行计划
2024-07-16

Oracle中如何分析执行计划和性能统计信息

在Oracle数据库中,可以通过以下几种方式来分析执行计划和性能统计信息:使用SQL语句explain plan来分析执行计划。可以在SQL语句前加上"explain plan for"关键字来生成该语句的执行计划。然后使用"select
Oracle中如何分析执行计划和性能统计信息
2024-04-09

如何通过修改注册表来改变windows桌面的文件所的目标位置

如何通过修改注册表来改变windows桌面的文件所的目标位置,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。大家经常在重装系统前,由于没有准备好,结果导致很多桌面上的文件没有保存
2023-06-14

编程热搜

目录