<div id="navCategory"></div>
讯享网
- :记录锁信息的表
- :记录会话信息的表
- :记录执行sql的表
- :用来管理对象(表、库等等对象)
- USERNAME:死锁语句所用的数据库用户;
- SID: session_id
- LOCKWAIT:死锁的状态,如果有内容表示被死锁。
- STATUS:状态,active表示被死锁
- MACHINE:死锁语句所在的机器。
- PROGRAM:产生死锁的语句主要来自哪个应用程序。
造成死锁的sql事务都必定是未提交的
附:数字越大锁级别越高, 影响的操作越多
1级锁有:Select,有时会在v$locked_object出现。
3级锁有:Insert, Update, Delete, Lock Row Exclusive
没有commit之前插入同样的一条记录会没有反应, 因为后一个3的锁会一直等待上一个3的锁, 我们必须释放掉上一个才能继续工作。
4级锁有:Create Index, Lock Share
locked_mode为2,3,4不影响DML(insert,delete,update,select)操作, 但DDL(alter,drop等)操作会提示ora-00054错误。

00054, 00000, "resource busy and acquire with NOWAIT specified"
// *Cause: Resource interested is busy.
// *Action: Retry if necessary.
5级锁有:Lock Share Row Exclusive
具体来讲有主外键约束时update / delete ... ; 可能会产生4,5的锁。
6级锁有:Alter table, Drop table, Drop Index, Truncate table, Lock Exclusive
到此这篇关于oracle数据库查看锁表的sql语句的文章就介绍到这了,更多相关oracle查看锁表sql内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/182370.html