您当前的位置:首页 > 电脑百科 > 数据库 > Oracle

Oracle数据库之如何快速查找未使用绑定变量的SQL语句

时间:2019-10-14 11:11:52  来源:  作者:

概述

Oracle在解析SQL语句的时候,如果在共享池中发现匹配的SQL语句,就可以避免掉解析的大部分开销。在共享池中找到匹配的SQL语句所对应的解析被称为软解析(soft parse)。如果没有找到匹配的SQL语句,则必须进行硬解析(hard parse)。

硬解析不仅耗费CPU时间,在有大量会话想要同时缓存SQL语句到共享池时还会造成争用。通过使用绑定变量,可以最小化解析的代价。

Oracle中有没使用绑定变量对于是否需要多次解析的影响是很大的,很多时候我们都要求开发变量尽量都使用绑定变量,但毕竟是要求,有人不遵守的话,我们也没辙,那么可以怎么去查找到这些未使用绑定变量的sql语句呢?


一、思路

利用V$SQL 视图的 FORCE_MATCHING_SIGNATURE 字段可以识别可能从绑定变量或CURSOR_SHARING获益的SQL语句。

如果 SQL 已使用绑定变量或者 CURSOR_SHARING ,那么FORCE_MATCHING_SIGNATURE 在对其进行标识时将给出同样的签名。换句话说,如果两个SQL语句除了字面量的值之外都是相同的,它们将拥有相同的FORCE_MATCHING_SIGNATURE,这意味着如果为它们提供了绑定变量或者CURSOR_SHARING,它们就成了完全相同的语句。

所以,使用FORCE_MATCHING_SIGNATURE字段可以识别没有使用绑定变来的SQL语句。


二、获取未使用绑定变量脚本

with force_mathces as
 (select l.force_matching_signature,
 max(l.sql_id || l.child_number) max_sql_child,
 dense_rank() over(order by count(*) desc) ranking,
 count(*) counts
 from v$sql l
 where l.force_matching_signature <> 0
 and l.parsing_schema_name <> 'SYS'
 group by l.force_matching_signature
 having count(*) > 10)
select v.sql_id,
 v.sql_text,
 v.parsing_schema_name,
 fm.force_matching_signature,
 fm.ranking,
 fm.counts
 from force_mathces fm, v$sql v
 where fm.max_sql_child = (v.sql_id || v.child_number)
 and fm.ranking <= 50
 order by fm.ranking;
Oracle数据库之如何快速查找未使用绑定变量的SQL语句

 

 


三、通过执行动态SQL语句获取绑定变量的好处

1、通过执行动态SQL语句,比较字面量和绑定参数对SQL解析的影响(注意用scott用户)

set serveroutput on;
​
declare
 v_ename emp.ename%type;
 v_sal emp.sal%type;
 v_sql clob;
begin
 dbms_output.put_line('*********使用字面量************');
 for vrt_emp in (select * from emp) loop
 v_sql := 'select e.ename,e.sal from emp e where e.empno =' ||
 vrt_emp.empno;
 execute immediate v_sql
 into v_ename, v_sql;
 dbms_output.put_line(v_ename || ':' || v_sql);
 end loop;
​
 dbms_output.put_line('');
 dbms_output.put_line('*********使用绑定变量************');
 for vrt_emp in (select * from emp) loop
 v_sql := 'select e.ename,e.sal from emp e where e.empno =:empno';
 execute immediate v_sql
 into v_ename, v_sql
 using vrt_emp.empno;
 dbms_output.put_line(v_ename || ':' || v_sql);
 end loop;
end;
/
Oracle数据库之如何快速查找未使用绑定变量的SQL语句

 


Oracle数据库之如何快速查找未使用绑定变量的SQL语句

 

2、查询v$sql视图,比较执行结果:

select v.sql_text, v.sql_id, v.force_matching_signature
 from v$sql v
 where v.sql_text like 'select e.ename,e.sal from emp e where e.empno %';
Oracle数据库之如何快速查找未使用绑定变量的SQL语句

 

在v$sql视图中,发现使用字面量的SQL语句有14条,而使用绑定变量的SQL语句只有一条。其中使用字面量的SQL语句除以了字面量值不同之外,其他部分都是相同。而FORCE_MATCHING_SIGNATURE的值是在假设该SQL语句使用绑定变量或者CURSOR_SHARING得到的,因此通过FORCE_MATCHING_SIGNATURE字段识别没有绑定变量的SQL语句。


四、查找未使用绑定变量的语句

1、从10G开始可以通过如下方式查找未使用绑定变量的语句

select FORCE_MATCHING_SIGNATURE, count(1) 
 from v$sql 
 where FORCE_MATCHING_SIGNATURE > 0 
 and FORCE_MATCHING_SIGNATURE != EXACT_MATCHING_SIGNATURE 
 group by FORCE_MATCHING_SIGNATURE 
having count(1) > &a 
 order by 2; 

2、10G以上通过如下过程可以查找对未使用绑定变量的语句

create table shsnc.long_sql(sql_text clob, FORCE_MATCHING_SIGNATURE number,count number) 
create or replace procedure query_sql is 
cursor fms is select FORCE_MATCHING_SIGNATURE as fms, count(1) as count 
 from v$sql 
 where FORCE_MATCHING_SIGNATURE > 0 
 and FORCE_MATCHING_SIGNATURE != EXACT_MATCHING_SIGNATURE 
 group by FORCE_MATCHING_SIGNATURE 
having count(1) > 100 
 order by 2; 
v_fms number; 
v_sql01 varchar2(3999); 
v_sql02 varchar2(3999); 
begin 
for i in fms loop 
v_sql01:='insert into shsnc.long_sql(FORCE_MATCHING_SIGNATURE,sql_text) select FORCE_MATCHING_SIGNATURE,sql_fulltext from (select FORCE_MATCHING_SIGNATURE,sql_fulltext from v$sql where FORCE_MATCHING_SIGNATURE='||i.fms||' and FORCE_MATCHING_SIGNATURE not in (select FORCE_MATCHING_SIGNATURE from shsnc.long_sql)) where rownum<2'; 
v_sql02:='update shsnc.long_sql set count='||i.count ||' where FORCE_MATCHING_SIGNATURE='||i.fms; 
execute immediate v_sql01; 
commit; 
execute immediate v_sql02; 
commit; 
end loop; 
end; 
/ 

10g以后v$SQL动态性能视图增加了FORCE_MATCHING_SIGNATURE列,其官方定义为”The signature used when the CURSOR_SHARING parameter is set to FORCE”,也就是Oracle通过将原SQL_TEXT转换为可能的FORCE模式后计算得到的一个SIGNATURE值。



Tags:Oracle 绑定变量   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
概述Oracle在解析SQL语句的时候,如果在共享池中发现匹配的SQL语句,就可以避免掉解析的大部分开销。在共享池中找到匹配的SQL语句所对应的解析被称为软解析(soft parse)。如果...【详细内容】
2019-10-14  Tags: Oracle 绑定变量  点击:(209)  评论:(0)  加入收藏
▌简易百科推荐
安装环境Linux服务器:Centos 6 64位Oracle服务器:Oracle11gR2 64位 系统要求说明:内存必须高于1G的物理内存;交换空间,一般为内存的2倍(1G的内存可以设置swap 分区为3G大小);硬...【详细内容】
2021-12-27  守护梦想2022    Tags:Oracle   点击:(2)  评论:(0)  加入收藏
1、 登陆CentOS 2、 查看备份脚本,脚本放在\usr\local目录下 3、 编写数据库备份脚本,内容如下 前提是需要在Oracle创建directory文件,如果没有,可以create创建并授权给相应的用...【详细内容】
2021-12-10  JasonTang    Tags:Oracle   点击:(14)  评论:(0)  加入收藏
之前写了个Oracle12c在Redhat6.8下的静默安装,操作系统版本太老了而且没配插图,今天重新写个centos 7 下静默安装。 准备环境:centos 7 虚拟机一台,Oracle12c安装包。1、检查防...【详细内容】
2021-10-12  it运维小土豆  今日头条  Tags:Oracle   点击:(29)  评论:(0)  加入收藏
JDK 17 正式发布+免费牛逼啊,JDK 16 刚发布半年(2021/03/16),JDK 17 又如期而至(2021/09/14),这个时间点牛逼啊,蹭苹果发布会的热度?记得当年 JDK 15 的发布也是同天,巧了。。虽然 iPho...【详细内容】
2021-09-16  Java技术栈  掘金  Tags:Oracle   点击:(88)  评论:(0)  加入收藏
Oracle日志文件是Oracle数据库存储信息的重要文件,主要用来存储数据库变化的操作信息。Oracle日志文件可以分为两种:重做日志文件(redo log file)、归档日志文件,其中重做日志文...【详细内容】
2021-08-19  free教程    Tags:Oracle日志   点击:(101)  评论:(0)  加入收藏
本例子在真实环境应用过,获得了很好的体验,特将其分享出来供各位朋友使用。后续我会持续把相关的知识一点一点的更新,请各位多多关注,多多支持。测试速度:导出速度大概800M/s,如...【详细内容】
2021-08-17  大树唛包    Tags:oracle   点击:(88)  评论:(0)  加入收藏
天冒险重启下Oracle rac,分三个步骤,停实例---停集群---重启服务器。 1、关闭实例检查状态su - gridcrsctl status res -t 注意:只在一个节点执行就行,或者为了保险期间,使用shut...【详细内容】
2021-07-16  死磕IT    Tags:Oracle rac   点击:(128)  评论:(0)  加入收藏
两个字符串相似度的比较:SYS.UTL_MATCH.edit_distance_similarity用法:select SYS.UTL_MATCH.edit_distance_similarity(&#39;河北沧州东塑股份有限公司&#39;,&#39;河北沧州东...【详细内容】
2021-07-07  Onceagain75783189    Tags:比较函数   点击:(112)  评论:(0)  加入收藏
现在有一个用户A,想把这个用户A下面的所有的表查询权限都赋予用户X,该怎么做?同样的问题,如果有4个用户A、B、C、D,需要把这4个用户下面所有的表的只读权限赋予用户X、Y、Z三个用...【详细内容】
2021-06-23  程序猿集锦    Tags:Oracle   点击:(103)  评论:(0)  加入收藏
oarcle数据库真正存放数据的是数据文件(data files),Oarcle表空间(tablespaces)实际上是一个逻辑的概念,他在物理上是并不存在的,那么把一组data files 捻在一起就成为一个表空间。...【详细内容】
2021-04-27  SQL小帅哥  今日头条  Tags:Oracle   点击:(200)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条