当前位置: 首页 > news >正文

Oracle 数据库的锁排查方法

关键字

oracle lock

问题描述

Oracle 数据库上锁问题如何排查

解决问题思路

准备数据
create table lock_test(name varchar(10),age varchar(10));insert into lock_test values('ff','10');
insert into lock_test values('yy','20');
insert into lock_test values('ll','30');Oracle 会话默认开启事务:
session1:
update lock_test set age = 'session1' where name = 'ff';session2:
update lock_test set age = 'session2' where name = 'ff';session2 因为更新同一行数据肯定 pending-- 查新活跃会话
select s.sid,s.sql_id,s.SQL_CHILD_NUMBER CHILD,s.USERNAME,s.CLIENT_INFO,s.LOGON_TIME,s.EVENT,s.BLOCKING_SESSION BLOCK,v.SQL_TEXTfrom V$SQL v right join v$session s  on v.sql_id=s.sql_idwhere  s.WAIT_CLASS<>'Idle'group by s.sid,s.sql_id,s.SQL_CHILD_NUMBER,s.USERNAME,s.CLIENT_INFO,s.LOGON_TIME,s.EVENT,s.BLOCKING_SESSION,v.SQL_TEXT;|SID|SQL_ID       |CHILD|USERNAME|CLIENT_INFO|LOGON_TIME             |EVENT                        |BLOCK|SQL_TEXT                                                                                                                                                                                                                                                                                                                                                                                                  |
|---|-------------|-----|--------|-----------|-----------------------|-----------------------------|-----|-----------------------------------------------------------
|8  |5cnbp94b459wf|0    |ADMIN   |           |2023-09-22 09:47:44.000|enq: TX - row lock contention|1,837|update lock_test set age = 'session2' where name = 'ff'                                                                                                                                                                                                                                                                                                                                                   |-- 查看正在锁的会话
SELECT * FROM V$SESSION_BLOCKERS;
SELECT * FROM V$SESSION_BLOCKERS  WHERE  BLOCKER_SID  NOT IN (SELECT SID  FROM V$SESSION_BLOCKERS);|SID|SESS_SERIAL#|WAIT_ID|WAIT_EVENT|WAIT_EVENT_TEXT              |BLOCKER_INSTANCE_ID|BLOCKER_SID|BLOCKER_SESS_SERIAL#|CON_ID|
|---|------------|-------|----------|-----------------------------|-------------------|-----------|--------------------|------|
|8  |59,610      |43     |307       |enq: TX - row lock contention|1                  |1,837      |43,494              |0     |-- 杀掉SESSION
SELECT DISTINCT  'ALTER SYSTEM KILL SESSION ''' || a.BLOCKER_SID  || ',' ||a."BLOCKER_SESS_SERIAL#" || ''';' FROM V$SESSION_BLOCKERS a ;|'ALTERSYSTEMKILLSESSION'''||A.BLOCKER_SID||','||A."BLOCKER_SESS_SERIAL#"||''';'|
|-------------------------------------------------------------------------------|
|ALTER SYSTEM KILL SESSION '1837,43494';                                        |模拟二
session1:
update lock_test set age = 'session1' where name = 'ff';session2:
alter table lock_test add  name1 varchar(100);以上方法可以查询处理

问题总结

Oracle 数据库的锁排查方法

http://www.lryc.cn/news/205848.html

相关文章:

  • 混合精度训练原理之float16和float32数据之间的互相转换
  • 网络协议--ICMP:Internet控制报文协议
  • 《红蓝攻防对抗实战》三.内网探测协议出网之HTTP/HTTPS协议探测出网
  • 【Win11】系统重装教程(最新最详细)
  • 如何构建一个外卖微信小程序
  • 小知识(5) el-table行样式失效问题
  • 【Docker】Docker数据的存储
  • hive字段关键字问题处理
  • 指定顺序输出
  • (Java)中的数据类型和变量
  • SHELL脚本编程基础,bilibili王晓春老师课程个人笔记(写比较简单,仅供参考)
  • VS code运行vue项目
  • matlab中narginchk函数用法及其举例
  • k8s集群镜像下载加gradana监控加elk日志收集加devops加秒杀项目
  • waf绕过
  • 在 MyBatis-Plus 中,如果你想通过其他字段进行修改操作,可以使用条件构造器(Wrapper)来指定修改的条件。
  • Python Opencv实践 - 入门使用Tesseract识别图片中的文字
  • TCP通信实战案例-即时通信
  • 【数据结构初阶】算法的时间复杂度和空间复杂度
  • git log 命令详解
  • docker运行elastic和kibana,并使用密码连接
  • 前端html生成PDF
  • 通信算法之190: 频谱频移fftshift
  • 强化学习代码实战(3) --- 寻找真我
  • SA+ST表维护height+单调队列维护:CF1073G
  • Java中JVM、JRE和JDK三者有什么区别和联系?
  • 秋季期中考复现xj
  • 【代码随想录】算法训练营 第十四天 第六章 二叉树 Part 1
  • 【访问控制】—>《熟练使用ACL进行上网行为管理》
  • MySQL外键,表与表的关系,多表查询,Navicat软件