Oracle如何查看已被使用的open_cursors&session_cached_cursors

这篇文章主要介绍Oracle如何查看已被使用的open_cursors&session_cached_cursors,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

公司主营业务:网站制作、成都网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联公司推出二连浩特免费做网站回馈大家。

查看当前session已使用的最大open cursor数 和cached cursor数:
SELECT 'session_cached_cursors' PARAMETER,
       LPAD (VALUE, 5) VALUE,
       DECODE (VALUE, 0, ' n/a', TO_CHAR (100 * USED / VALUE, '990') || '%')
          USAGE
  FROM (SELECT MAX (S.VALUE) USED
          FROM V$STATNAME N, V$SESSTAT S
         WHERE     N.NAME = 'session cursor cache count'
               AND S.STATISTIC# = N.STATISTIC#),
       (SELECT VALUE
          FROM V$PARAMETER
         WHERE NAME = 'session_cached_cursors')
UNION ALL
SELECT 'open_cursors',
       LPAD (VALUE, 5),
       TO_CHAR (100 * USED / VALUE, '990') || '%'
  FROM (  SELECT MAX (SUM (S.VALUE)) USED
            FROM V$STATNAME N, V$SESSTAT S
           WHERE     N.NAME IN ('opened cursors current',
                                'session cursor cache count')
                 AND S.STATISTIC# = N.STATISTIC#
        GROUP BY S.SID),
       (SELECT VALUE
          FROM V$PARAMETER
         WHERE NAME = 'open_cursors');
注:如果查询的session open cursor到达100% client就很可能报错ORA-01000

查看session open cursor的具体程式、open cursor数量:
SELECT a.inst_id,
     a.sid,
     a.USERNAME,
     a.SCHEMANAME,
     a.OSUSER,
     a.machine,
     a.TERMINAL,
     a.LOGON_TIME,
     a.PROGRAM,
     a.STATUS,
     b.name,
     b.used
FROM gv$session a,
     (SELECT n.inst_id,
             sid,
             n.name,
             s.VALUE used
        FROM gv$statname n, gv$sesstat s
       WHERE     n.name IN ('opened cursors current',
                            'session cursor cache count')
             AND s.statistic# = n.statistic#
             AND n.inst_id = s.inst_id) b
WHERE     a.sid = b.sid
     AND a.inst_id = b.inst_id
     AND b.name <> 'session cursor cache count'
ORDER BY b.used DESC;

查看session open cursor的具体SQL(此方法是联合v$open_cursor得出的结果,可能有不准确。但session最多open_cursors的SQL一定是在运行结果中)
SELECT distinct a.inst_id,
         a.sid,
         a.USERNAME,
         a.SCHEMANAME,
         a.OSUSER,
         a.machine,
         a.TERMINAL,
         a.LOGON_TIME,
         a.PROGRAM,
         a.STATUS,
         b.name,
         b.used,c.sql_id
  FROM   gv$session a,
         (SELECT   n.inst_id, sid, n.name, s.VALUE used
            FROM   gv$statname n, gv$sesstat s
           WHERE   n.name IN
                         ('opened cursors current',
                          'session cursor cache count')
                   AND s.statistic# = n.statistic# and n.inst_id=s.inst_id ) b,v$open_cursor c
 WHERE   a.sid = b.sid and a.inst_id = b.inst_id and a.sid=c.sid and c.CURSOR_TYPE in('OPEN','OPEN-PL/SQL','OPEN-RECURSIVE')
 and b.name <> 'session cursor cache count'
 order by b.used desc;

以上是“Oracle如何查看已被使用的open_cursors&session_cached_cursors”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!

当前标题:Oracle如何查看已被使用的open_cursors&session_cached_cursors
文章源于:https://www.cdcxhl.com/article24/ijccje.html

成都网站建设公司_创新互联,为您提供营销型网站建设电子商务网站改版微信小程序手机网站建设面包屑导航

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

搜索引擎优化