数据库阻塞和锁

1.阻塞可以等待或者干掉一个

1.1当执行程序的时候前端如果正常流程没响应了;服务端也没见报错很大程度操作的数据再等另一个事务的处理。

1.2前端没响应还有个服务端的情形,起了一个事务更新了某条数据但是事务没提交,这时候又起了一个事务处理这条数据等待前面的事务提交导致程序走不下去,这种情况再手动操作jdbc的时候发生的概率大点,spring控制的话因为一个线程走的是一个事务规避了这种情形

A事务处理某条数据L1事务未结束锁未释放

B事务也处理数据L1需要等待A事务结束锁释放,不然B处理处于等待中

2.阻塞处理查找问题了,看看是程序问题还是手工操作问题

oracle 复制代码
--未提交事务的sql
select s.sid,
       s.username,
       s.osuser,
       s.program,
       to_char(s.LOGON_TIME, 'yyyymmdd hh24:mi:ss')       as LOGON_TIME,
       to_char(t.START_DATE, 'yyyymmdd hh24:mi:ss')       as START_DATE,
       s.status,
       (select q.SQL_TEXT from v$sql q where q.LAST_ACTIVE_TIME = t.START_DATE
                                         and rownum <= 1) as SQL_TEXT
from v$session s,
     v$transaction t
where s.sADDR = t.SES_ADDR;

3.锁跟线程锁一个道理的只有干掉其中一个

根据测试数据orace检测到死锁会主动给个报错的

A事务处理数据L1, L2

B事务处理数据L2, L1

事务A、B都阻塞只有干掉其中一个

4.死锁处理办法

能避免的一个事务一个处理程序控制。

避免不了的按照同样资源顺序进行处理。

5.锁或阻塞事务查看

oracle 复制代码
SELECT SESS.SID,  SESS.SERIAL#,  LO.ORACLE_USERNAME,  LO.OS_USER_NAME,  AO.OBJECT_NAME 被锁对象名, LO.LOCKED_MODE 锁模式, sess.LOGON_TIME 登录数据库时间,
'ALTER SYSTEM KILL SESSION ''' || SESS.SID || ','||SESS.SERIAL#||'''' FREESQL
FROM V$LOCKED_OBJECT LO,  DBA_OBJECTS AO,  V$SESSION SESS 
WHERE AO.OBJECT_ID = LO.OBJECT_ID AND LO.SESSION_ID = SESS.SID ORDER BY sid, sess.serial#;
相关推荐
梁下轻语的秋缘37 分钟前
ESP32-WROOM-32E存储全解析:RAM/Flash/SD卡读写与速度对比
java·后端·spring
wanzhong233340 分钟前
开发日记8-优化接口使其更规范
java·后端·springboot
羊小猪~~2 小时前
【QT】--文件操作
前端·数据库·c++·后端·qt·qt6.3
张彦峰ZYF2 小时前
商品供给域的工程化简要设计考量
后端·系统架构·商品模型·商品供给
小北方城市网4 小时前
微服务注册中心与配置中心实战(Nacos 版):实现服务治理与配置统一
人工智能·后端·安全·职场和发展·wpf·restful
橘子134 小时前
MySQL库的操作(二)
数据库·mysql·oracle
·云扬·4 小时前
MySQL各版本核心特性演进与主流分支深度解析
数据库·sql·mysql
爬山算法5 小时前
Hibernate(47)Hibernate的会话范围(Scope)如何控制?
java·后端·hibernate
源码宝6 小时前
云HIS二次开发实施路径指南
后端·源码·二次开发·saas·云his·医院信息系统
coding者在努力8 小时前
SQL使用NOT EXITS实现全称量词查询(数据库查询所有)详细讲解和技巧总结
网络·数据库·sql