Oracle使用SPM对含有绑定变量SQL做固定的方法
2021/11/3 19:13:42
本文主要是介绍Oracle使用SPM对含有绑定变量SQL做固定的方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Oracle使用SPM对含有绑定变量SQL做固定的方法
一般SPM固定如果目标SQL没有绑定变量,那么直接对目标SQL添加HINT然后产生的执行计划用SPM来“偷天换日”。
如果是含有绑定变量,这里有两种情况。
情况1:select * from t where t.id=:A;
这种情况可以使用定义变量A后赋值然后添加HINT到含有绑定变量的原SQL中执行以获取想要的执行计划然后用SPM替换并固定。
var A number; exec :A := 100; select * from t where t.id=:A; --获取SQL_ID和执行计划(含有Plan Hash值) select * from table(dbms_xplan.display_cursor(null,null,'allstats last'));
情况2:select * from t where t.id=:1;
由于变量名无法用数据定义,因此情况1不适用。
可以通过视图DBA_HIST_SQLBIND或者GV$SQL_BIND_CAPTURE获取绑定变量值然后直接替换到原SQL中,获取想要的执行计划然后用SPM替换并固定。
经过两次不同SQL的测试,此种方式是可行的。
这篇关于Oracle使用SPM对含有绑定变量SQL做固定的方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-04el-table 开启定时器下,表格的选中状态会消失是什么原因-icode9专业技术文章分享
- 2024-10-03如何安装和初始化飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03如何安装 App 并连接到飞牛 NAS?-icode9专业技术文章分享
- 2024-10-03如何安装飞牛 TV 并连接到影视服务器?-icode9专业技术文章分享
- 2024-10-03如何在PVE和ESXI上安装飞牛私有云 fnOS?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS安装系统异常情况处理-icode9专业技术文章分享
- 2024-10-03飞牛NAS如何创建存储空间?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS硬盘会自动休眠吗?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何安装飞牛影视和创建媒体库?-icode9专业技术文章分享
- 2024-10-03fnOS国产最强NAS如何为家人朋友开通影视账号?-icode9专业技术文章分享