oracle数据库被锁住问题

本文深入探讨了Java中数据库操作的锁机制,包括同一事务内更新操作的影响、并发事务间的锁竞争以及如何避免死锁。强调了手动提交可能导致的问题及正确的提交策略。

数据库被锁问题:
java中对数据库操作时最近老是出现被锁住问题,总结一下。
1.同一个事务里如果对某一张表进行更新之后再进行其他操作,例如:insert,这时数据库是不会上锁的,因为是在同一个事务里,等更新操作全部结束之后,这个事务会统一提交。
2.假如A和B两个事务同时对某一条数据进行更新操作,如果A事务先开始执行,那么A事务所操作的这部分数据被锁定,B事务无法进行修改,B事务会等待A事务动作提交之后才开始执行,如果等待超时,B事务会取消动作。
3.我的代码中看到自己是手动提交的,这样A事务永远不会提交,B事务会一直等待,就会造成死锁。所以一般java中操作数据库时一般使用同一个连接统一进行提交和回滚。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值