当前位置:  数据库>oracle

如何获取Oracle share pool中没有使用绑定变量的SQL

    来源: 互联网  发布时间:2017-06-02

    本文导语: 网站提供了一个函数remove_constants,来检查共享池中的SQL运行情况,处理思路是将查询条件值变为一个通用标记,如:select * from t where object_id=1替换成select * from t where object_id=@ 。 SQL> drop table find_no_bind purge;SQL> create table t as select *...

网站提供了一个函数remove_constants,来检查共享池中的SQL运行情况,处理思路是将查询条件值变为一个通用标记,如:select * from t where object_id=1替换成select * from t where object_id=@ 。

SQL> drop table find_no_bind purge;
SQL> create table t as select * from dba_objects where 1=2;

--创建纪录表
SQL> create table find_no_bind as select sql_text from v$sqlarea;
SQL> alter table find_no_bind add sql_text_copy varchar2(1000);

--创建替换函数,把占位符替换成@
create or replace function
SQL> remove_constants( p_query in varchar2 ) return varchar2
as
    l_query long;
    l_char  varchar2(1);
    l_in_quotes boolean default FALSE;
begin
    for i in 1 .. length( p_query )
    loop
        l_char := substr(p_query,i,1);
        if ( l_char = '''' and l_in_quotes )
        then
            l_in_quotes := FALSE;
        elsif ( l_char = '''' and NOT l_in_quotes )
        then
            l_in_quotes := TRUE;
            l_query := l_query || '''#';
        end if;
        if ( NOT l_in_quotes ) then
            l_query := l_query || l_char;
        end if;
    end loop;
    l_query := translate( l_query, '0123456789', '@@@@@@@@@@' );
    for i in 0 .. 8 loop
        l_query := replace( l_query, lpad('@',10-i,'@'), '@' );
        l_query := replace( l_query, lpad(' ',10-i,' '), ' ' );
    end loop;
    return upper(l_query);
end;
/


--先清一下share pool,正式环境不能这么干

SQL> alter system flush shared_pool;


SQL> begin
for i in 1..1000 loop
execute immediate 'select * from t where OBJECT_ID = '||i;
end loop;
end;
/


SQL> update find_no_bind set sql_text_copy = remove_constants(sql_text);

SQL> commit;


SQL> col sql_text_copy format a40
SQL> select sql_text_copy, count(*)
  2    from find_no_bind
  3  group by sql_text_copy
  4  having count(*) > 10;
SQL_TEXT_COPY                              COUNT(*)
---------------------------------------- ----------
SELECT * FROM T WHERE OBJECT_ID = @            1000

 


    
 
 

您可能感兴趣的文章:

  • 1.请问如何编程获取网关ip地址 2.如何在一块网卡中绑定多个ip地址?
  • c#的treeview绑定和获取值的方法
  • 程序中获取的环境变量能够根据Linux系统中相应环境变量而变化吗?
  • C语言调用shell脚本后,通过何种方法能获取脚本中变量的值
  • Qt如何获取系统的环境变量?
  • 在java中如何获取window中环境变量path的值!!!高分
  • 请问:如何获取文件系统/home的占有量,赋值与变量a
  • IT科技资讯 iis7站长之家
  • UNIX shell中获取C代码中设置的环境变量。
  • 在c#中把字符串转为变量名并获取变量值的小例子
  • <<java编程思想>>的一道练习题???写一个程序,打印出从命令行获取的三个自变量?解决即结帖
  • php 获取一个变量名字的二种方法
  • linux下shell的脚本无法获取别的用户的环境变量
  • PHP代码优化之成员变量获取速度对比
  • PHP标记风格、注释、表单获取、字符串类型、变量解析的实例解析
  • 征求解答。如何获取系统变量?急!!!
  • php获取当前url路径 php服务器变量
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux中到底有没有获取CPU使用率的API?
  • 有没有人知道哪里可以获取到实时的股票交易数据?
  • 有没有办法获取远程用户的MAC地址?
  • 有没有函数从html文本中获取纯文本内容???
  • Python获取网页编码的方法及示例代码
  • linux不用命令方式读文件获取网络流量,如何使用C函数调用获取网络流量信息?
  • java Servlet获取和设置cookie实例代码
  • 关于获取在jsp上获取客户端时间的问题
  • Python通过正则表达式获取,去除(过滤)或者替换HTML标签的几种方法
  • 关于Ganglia中的gmond组件收集到的资源信息如何获取(如何获取telnet后返回的信息)
  • php获取访客ip地址原理及提供七段代码供参考
  • java获取系统路径字体、得到某个目录下的所有文件名、获取当前路径
  • 利用sender的Parent获取GridView中的当前行(获取gridview的值)
  • php获取本机ip地址 php获取远程IP地址
  • linux获取主机名后用gethostbyname() 不能获取主机ip
  • javascript 获取url参数的正则表达式(用来获取某个参数值)
  • 在gtk下,怎样获取系统时间??怎样获取当前的目录路径???
  • C++获取文件哈希值(hash)和获取torrent(bt种子)磁力链接哈希值
  • linux根据pid获取进程名和获取进程pid(c语言获取pid)
  • Shell获取系统时间问题
  • android 如何获取MCC/MNC控制小区广播的开启
  • 新手问题:Linux下如何获取进程占用的系统资源
  • c++如何获取当前进程名
  • 怎么通过snmp获取远程主机指定进程信息?
  • C#获取路径的多种方法


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,