找回密码
 立即注册
首页 业界区 业界 SQL优化必备脚本:Oracle获取绑定变量的字面SQL文本 ...

SQL优化必备脚本:Oracle获取绑定变量的字面SQL文本

吮槌圯 昨天 19:57
我们的文章会在微信公众号IT民工的龙马人生和博客网站( www.htz.pw )同步更新 ,欢迎关注收藏,也欢迎大家转载,但是请在文章开始地方标注文章出处,谢谢!
由于博客中有大量代码,通过页面浏览效果更佳。
今天分享一个使用了10多年的脚本,此脚本可以说是我使用频率排在前10的一个脚本。此脚本解决我们在优化SQL语句时,我们需要去查看SQL语句未绑定变量的字面SQL文本,如果SQL语句只有1、2个SQL语句,我们可以通过手动的方式去查询v$SQL_BIND_CAPTURE的绑定变量值来修改,但是如果我们有10个以上的绑定变量,通过此方法的效率就非常低,就需要依赖下面的脚本一键获取SQL的字面文本。虽然是用了10多年的SQL语句,但是此SQL语句原来一直只支持绑定变量的SQL语句,如果SQL没有使用绑定变量,返回为空。今天终于添加了一个判断了,非绑定变量的SQL直接显示文本即可。
此脚本功能非常简单,这里就只简单演示一下直接后的结果即可:
绑定变量的情况
  1. SQL> @sql_fulltext_by_sqlid.sql
  2. Enter value for sqlid: f4k1vwyb1400d
  3. HTZHTZ
  4. select temp0001.id as id847_ from htztable temp0001 where (temp0001.doc_resource_id in
  5. (7531984628351947269 , 8462951738649371528 , 3958471625948361729 ,
  6. 829475163847291635 , 5948371628473951728 )) and (temp0001.change_type in (0
  7. , 1 ))
  8. 原始SQL的文本如下:
  9. select temp0001.id as id847_from htztable temp0001 where (temp0001.doc_resource_id in
  10. (:1 , :2 , :3 , :4 , :5 )) and (temp0001.change_type in (:6 , :7 ))
复制代码
未绑定变量的SQL
  1. @sql_fulltext_by_sqlid.sql
  2. Enter value for sqlid: f4k1vwyb1400d
  3. Schema: HTZZ
  4. SELECT  htz.budgetcheck, htz.yhhd_no, htz.iprintcount from table_1 htz where htz.dr = 0
  5. and htz.vouchid = '1106ZZ1000000000BPY0'
  6. --------------------------------------------------------
复制代码
脚本获取

脚本已经上传到微信群里面的共享链接文件,直接用共享链接下载即可。
------------------作者介绍-----------------------
姓名:黄廷忠
现就职:Oracle中国高级服务团队
曾就职:OceanBase、云和恩墨、东方龙马等
电话、微信、QQ:18081072613
个人博客: (http://www.htz.pw)
CSDN地址: (https://blog.csdn.net/wwwhtzpw)
博客园地址: (https://www.cnblogs.com/www-htz-pw)
1.png


来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册