查看 运行中的存储过程

1、查看ORACLE中正在运行的存储过程

SQL> select owner,name from v$db_object_cache where type like '%PROCE%' and locks >0 and pins >0;

OWNER         NAME

--------      ------

SYS          FULL_SCAN_BERTHDATAENTITY

 

SQL> select * from v$access o where o.OBJECT like 'FULL_SCAN_BERTHDATAENTITY%';

 

      SID OWNER   OBJECT                     TYPE

---------- ------- -------------------------- --------

1047 SYS     FULL_SCAN_BERTHDATAENTITY  PROCEDURE

 SQL> select * from v$session a WHERE A.SID=1047

2、停止正在运行的存储过程
可以查看正在运行的SESSION,把相应存储过程的SESSIONKILL掉即可!存储过程中的SQL都是可以跟踪到的(SESSION
select * from v$access o where o.OBJECT like 'FULL_SCAN_BERTHDATAENTITY%'
select * from v$session a WHERE A.SID=sid
alter system kill session 'sid,serial#'

3、动态性能表--V$DB_OBJECT_CACHE

  本视图提供对象在library cache(shared pool)中对象统计,提供比v$librarycache更多的细节,并且常用于找出shared pool中的活动对象。

v$db_object_cache中的常用列:

OWNER:对象拥有者
NAME
:对象名称
TYPE
:对象类型(如,sequence,procedure,function,package,package body,trigger)
KEPT
:告知是否对象常驻shared pool(yes/no),有赖于这个对象是否已经利用PL/SQL过程DBMS_SHARED_POOL.KEEP“保持(永久固定在内存中)
SHARABLE_MEM
:共享内存占用
PINS
:当前执行对象的session
LOCKS
:当前锁定对象的session

瞬间状态列:
下列列保持对象自初次加载起的统计信息:
LOADS
:对象被加载次数。

示例:
1.shared pool
执行以及内存使用总计
下列查询显示出shared pool内存对不同类别的对象
同时也显示是否有对象通过DBMS_SHARED_POOL.KEEP()过程常驻shared pool
SELECT type, kept, COUNT(*), SUM(sharable_mem)
FROM V$DB_OBJECT_CACHE
GROUP BY type, kept;

2.通过载入次数找出对象
SELECT owner, name sharable_mem, kept, loads
FROM V$DB_OBJECT_CACHE
WHERE loads > 1 ORDER BY loads DESC;

3.找出使用的内存超过10M并且不在常驻内存的对象。
SELECT owner, name, sharable_mem, kept
FROM V$DB_OBJECT_CACHE
WHERE sharable_mem > 102400 AND kept = 'NO'
ORDER BY sharable_mem DESC;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值