- 2
- 0
- 约5.5千字
- 约 4页
- 2021-11-25 发布于河北
- 举报
锁等待的诊断及排除
=====================================
在 ORACLE 中,为了保证数据的一致性, 在对数据库中的数据进行操作时, 系统会进行对数据相应的锁定。
当程序对所做的修改进行提交 (commit) 或回滚后 (rollback) 后,锁住的资源便会得到释放, 从而允许其它
用户进行操作。
但是,有时,由于程序中的原因,锁住资源后长时间未对其工作进行提交;或是由于用户的原因,如调出
需要修改的数据后,未及时修改并提交,而是放置于一旁;或是由于客户服务器方式中客户端出现 死机 ,
而服务器端却并未检测到,从而造成锁定的资源未被及时释放,影响到其它用户的操作。
这时,我们需要迅速地诊断出锁住资源的用户并解决其锁定。
1. 诊断系统中的锁
为了找出系统中那些用户锁住资源以及那些用户在等待相应的资源,可使用以下语句 ( 其中的 /*+
NO_MERGE(..) */ 千万不可省略 , 否则会很慢 ) :
-- looklock.sql
-- use the NO_MERGE hints can speed up the query
select /*+ NO_MERGE(a) NO_MERGE(b) NO_MERGE(c) */ Wait Status, a.username,
a.machine, a.sid, a.serial#, a.last_call_et Seconds, b.id1, c.sql_text SQL
from v$session a, v$lock b, v$sqltext c
where a.username is not null
and a.lockwait = b.kaddr
and c.hash_value =a.sql_hash_value
union
select /*+ NO_MERGE(a) NO_MERGE(b) NO_MERGE(c) */ Lock Status, a.username,
a.machine, a.sid, a.serial#, a.last_call_et Seconds, b.id1, c.sql_text SQL
from v$session a, v$lock b, v$sqltext c
where b.id1 in
(select /*+ NO_MERGE(d) NO_MERGE(e) */ distinct e.id1
from v$session d, v$lock e
where d.lockwait = e.kaddr)
and a.username is not null
and a.sid = b.sid
and b.request=0
and c.hash_value =a.sql_hash_value;
执行后的结果如下所示:
Stat USERNAME MACHINE SID SERIAL# Seconds ID1
SQL
Lock CIQUSR CIQ\DULMACER 12 966 245 131089
select * from c_trade_mode for update
Wait CIQUSR CIQ\DULMACER 10 735 111 131089
update c_trade_mode set x_name = zzz where x_code=5
Wait CIQUSR CIQ\DULMACER 15 106 1094 131089
select * from c_trade_mode for update
其中:
Status 有两种状态, LOCK 表明该进程锁住了某个资源, WAIT 表示该进程正在等待某个资源。
Username, Machine 分别为 ORACLE 用户名及机器名
SID ,SERIAL# 可用于随后的解锁操作
Second
您可能关注的文档
最近下载
- 山东省地震局招聘考试真题2024.docx VIP
- 2026年鹤壁职业技术学院单招职业适应性考试题库完整.docx VIP
- 2025年南京市中考语文试题卷(含答案解析).docx
- 2026年入党积极分子考试题库附答案【精练】.docx VIP
- 储能电站基础知识培训.docx
- 《GB6441-2025生产安全事故分类与编码》修改对比解析.pptx
- 部编年小学语文一年级下册看拼音写词语.doc VIP
- (正式版)HG-T 21633-2024 玻璃钢管和管件选用规定.pdf VIP
- 第2课 巩固人民民主政权 大单元教学课件 2026人教版历史八年级下册.ppt
- 2021款吉利领克01_汽车使用手册用户操作图示驾驶指南车主车辆说明书电子版.pdf
原创力文档

文档评论(0)