get_locked_objects_rpt.sql
在metalink上看到一个脚本(get_locked_objects_rpt.sql),非常不错,如下所示
/*----------------------------------------------------------------------------+
| MODULE: get_locked_objects_rpt.sql
|
| DESCRIPTION:
|
| Script to retrieve a list of locked objects from the database and identify
| the object being locked, and its rowid, and the SQL being blocked.
|
| INFORMATION:
|
| BRM Performance Tools ...
|
| REVISION:
|
| $Revision: 1.4 $
| $Author: pin $
| $Date: 2013/09/16 13:15:22 $
+----------------------------------------------------------------------------*/
set serveroutput on size unlimited
set feedback off
DECLARE
v_num_sessions INTEGER := 0;
CURSOR cv IS
SELECT dba_objects.object_name,
locks_t.row#,
locks_t.blocked_secs,
locks_t.blocker_text,
locks_t.blocked_text,
locks_t.blocked_sql_text
FROM (SELECT /*+ NO_MERGE */
blocking_lock_session.username||'@'||blocking_lock_session.machine||'(SID='||blocking_lock_session.sid||') ['||
blocking_lock_session.program||'/PID='||blocking_lock_session.process||']' as blocker_text,
blocked_lock_session.username||'@'||blocked_lock_session.machine|| '(SID='||blocked_lock_session.sid||') ['||
blocked_lock_session.program||'/PID='||blocked_lock_session.process||']' as blocked_text,
blocked_lock_session.row_wait_obj#,
blocked_lock_session.row_wait_file#,
blocked_lock_session.row_wait_block#,
blocked_lock_session.row_wait_row#,
DBMS_ROWID.ROWID_CREATE (1,
blocked_lock_session.row_wait_obj#,
blocked_lock_session.row_wait_file#,
blocked_lock_session.row_wait_block#,
blocked_lock_session.row_wait_row#) row#,
blocked_lock_session.seconds_in_wait blocked_secs,
blocked_sql.sql_text blocked_sql_text
FROM v$lock blocking_lock,
v$session blocking_lock_session,
v$lock blocked_lock,
v$session blocked_lock_session,
v$sql blocked_sql
WHERE blocking_lock.block = 1
AND blocking_lock.id1 = blocked_lock.id1
AND blocking_lock.id2 = blocked_lock.id2
AND blocked_lock.request > 0
AND blocking_lock.sid = blocking_lock_session.sid
AND blocked_lock.sid = blocked_lock_session.sid
AND blocked_lock_session.sql_id = blocked_sql.sql_id
AND blocked_lock_session.sql_child_number = blocked_sql.child_number
) locks_t,
dba_objects
WHERE locks_t.row_wait_obj# = dba_objects.object_id
AND locks_t.blocked_secs > &1
ORDER BY locks_t.blocked_secs;
BEGIN
FOR cv_rec IN cv LOOP
dbms_output.put_line(
'========= $Revision: 1.4 $ ($Date: 2013/09/16 13:15:22 $) ===========');
v_num_sessions := v_num_sessions + 1;
dbms_output.put_line('Locked object : '||
cv_rec.object_name);
dbms_output.put_line('Locked row# : '||
cv_rec.row#);
dbms_output.put_line('Blocked for : '||
cv_rec.blocked_secs||' seconds');
dbms_output.put_line('Blocker info. : '||
cv_rec.blocker_text);
dbms_output.put_line('Blocked info. : '||
cv_rec.blocked_text);
dbms_output.put_line('Blocked SQL : '||
cv_rec.blocked_sql_text);
END LOOP;
dbms_output.new_line;
dbms_output.put_line('Found '||TO_CHAR(v_num_sessions)||
' blocked session(s).');
END;
/
exit;
那么我们来测试一下,新建3个会话来测试验证:
1: 在会话ID为11的窗口执行下面SQL语句
SQL> create table test(id number, name varchar2(12));
Table created.
SQL> insert into test values(1001,'kerry');
1 row created.
SQL> commit;
Commit complete.
SQL> update test set name='jimmy' where id=1001;
1 row updated.
2:在会话ID为192的窗口执行下面语句。
SQL> update test set name='tina' where id=1001;
1 row updated.
3: 在会话窗口3执行下面语句查看阻塞或锁定对象情况,输入查询阻塞多少秒以上的SQL
[oracle@DB-Server ~]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.1.0 Production on Fri Aug 19 16:14:25 2016
Copyright (c) 1982, 2009, Oracle. All rights reserved.
Connected to:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
SQL> @get_locked_objects_rpt.sql
Enter value for 1: 10
old 42: AND locks_t.blocked_secs > &1
new 42: AND locks_t.blocked_secs > 10
========= $Revision: 1.4 $ ($Date: 2013/09/16 13:15:22 $) ===========
Locked object : TEST
Locked row# : AAASEkAAEAAAADUAAA
Blocked for : 34 seconds
Blocker info. : TEST@DB-Server.localdomain(SID=11)
[sqlplus@DB-Server.localdomain (TNS V1-V3)/PID=3971]
Blocked info. : TEST@DB-Server.localdomain(SID=192)
[sqlplus@DB-Server.localdomain (TNS V1-V3)/PID=4046]
Blocked SQL : update test set name='tina' where id=1001
Found 1 blocked session(s).
Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
参考资料:
Information To Collect When High Row-Lock Contention Is Seen In The BRM DB (文档 ID 1356147.1)
get_locked_objects_rpt.sql相关推荐
- 为什么数据库有时候不能定位阻塞(Blocker)源头的SQL语句
在SQL Server数据库或OACLE数据库当中,通常一个会话持有某个资源的锁,而另一个会话在请求这个资源,就会出现阻塞(blocking).这是DBA经常会遇到的情况.当出现SQL语句的阻塞时,很 ...
- java 必备面试必备
1.JDK 和 JRE 有什么区别? JDK(Java Development Kit),Java开发工具包 JRE(Java Runtime Environment),Java运行环境 JDK中包含 ...
- sql特殊字符转义,oracle中将字符 ‘ 转义
oracle中使用sql语句或多或少地会遇到使用特殊字符,比如" ' ",这时,这个单引号就会与前面的单引号匹配,将文本从中间断开,引发问题和错误.这就需要我们进行转义. 而ora ...
- weblogic项目java.sql.SQLException: ORA-01861: 文字与格式字符串不匹配 at oracle.jdbc.....错误解决
原因:数据源配置时间格式问题 解决方案: 1.进入weblogic控制台 2.左侧菜单栏选择Service- JDBC- Data Source 3.选择你的数据源,然后进入Configuration ...
- 如何定位并优化慢查询Sql
根据慢日志定位慢查询SQL. 查询慢日志相关变量,并进行设置: 主要关注下述三个变量: long_query_time.show_query_log_file.show_query_log 慢查询sq ...
- Go 学习笔记(55)— Go 标准库 sql (初始化数据库、插入、更新、删除数据库表、单行查询、多行查询、事务处理)
1. 标准库说明 Go 的标准库中是没有数据库驱动,只提供了驱动接口,有很多第三方实现了驱动,我们这里选择 go-sql-driver 这个实现是目前使用最多的.github 地址是:https:// ...
- SQL与NoSQL的区别 以MySQL与MongoDB为例
异同对比 1.语言和结构层面 SQL数据库,是基于表的,并且用结构化语言也就是SQL来定义和操纵数据.一方面,这是非常强大的:SQL是最通用和最广泛使用的选项之一,使其成为一个安全的选择,尤其适用于复 ...
- 【Sql Server】数据库的3大服务
在数据库SQL SERVER中,处理常用的sql server数据库引擎,还有其他3大服务,分别是集成服务,报表服务,分析服务. 集成服务商可以配置包,这里的包可以理解是数据库引擎里的用户数据库.可以 ...
- 【Sql Server】DateBase-自动化
强大的SQL Server有着神奇的自动化功能,来处理一些人为处理不了的事情! 自动化功能:T-sql语言,系统命令.脚本语言.复制命令.创建角色.索引重建.报表 管理元素:作业.警报.操作员.计划 ...
最新文章
- 利用人工智能(Magpie开源库)给一段中文的文本内容进行分类打标签
- 《CCNP ROUTE (642-902 )认证考试指南》一1.2 将考试主题与典型网络工程师的工作关联起来...
- P2221 [HAOI2012]高速公路
- python海龟图 如何控制线的粗细_使用Python中的高级turtle(海龟)作图方法
- VSCode注册关联自定义类型文件
- 深入理解javascript原型和闭包(8)——简述【执行上下文】上
- .NetCore 下开发独立的(RPL)含有界面的组件包 (四)授权过滤
- 团队计划(4.27)
- Keep Network启动下一阶段流动性挖矿计划
- html5 播放加密视频播放器,.NET MVC对接POLYV——HTML5播放器播放加密视频
- java+opencv实现人脸识别
- CentOS7 WordPress无法将上传的文件移动至wp-content/uploads/ ApacheNginx解决方案
- python 等值面_ANSYS Fluent快速添加等值面/等值线 源代码-教育代码类资源
- A feature-supervised generative adversarial network for environmental monitoring during hazy days
- 什么是WAF防火墙以及具体作用
- 两分钟教你学会视频添加滚动字幕并调整色调
- 【数据结构与算法】起始篇
- 数字抽奖小程序_发挥想象力,用 PowerBI 做抽奖小程序
- vue3 预览docx文件
- Python 多环境搭建方法
热门文章
- Linux查看当前http连接,51CTO博客-专业IT技术博客创作平台-技术成就梦想
- Linux上快速搭建Jenkins服务器 实现持续集成开发
- Google Guava 库用法整理
- 2019.3.23 python的unittest框架与requests
- python 数据分析工具之 numpy pandas matplotlib
- SharePoint 2007 URL地址快速一览表
- Metasploit Framework(1)基本命令、简单使用
- 21.Odoo产品分析 (三) – 人力资源板块(2) – 工时表(1)
- JVM堆内存控制/分代垃圾回收
- 内网网段划分ciso交换机配置