java - 在并发的情况下,程序事务和数据库事务是怎么运行的?
本文介绍了java - 在并发的情况下,程序事务和数据库事务是怎么运行的?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
@Transactional
public void selectAndUpdate() {
status = select ... for update;
if(status!="初始值") {
return;
}
//逻辑开始
程序逻辑 ...
举例:用户支付
1.生成用户签名
2.发起用户支付到第三方
//逻辑结束
update status语句...
}
如果利用这种方式来控制并发会有什么问题?另外我还想问大家的是:多个线程的话,会不会导致当一个线程执行到程序逻辑那块的时候,资源被另一个线程抢去的可能?导致另一个线程进入这个方法,发现状态还是没有被改变,然后又进入程序逻辑这块,导致两个线程都执行了一遍吗?数据库的一个事务没有完成的话,会让另外一个线程的事务进入吗?
解决方案
for update
的缺点@Hisoka已经说了,for update
除了会阻塞其它线程以外,加锁的过程对数据库的性能损耗也是很大的。
所以推荐使用乐观锁来解决,因为程序逻辑这块都是在内存中操作不涉及原始的数据,所以只需要在update status
语句...这里使用乐观锁来控制状态就行了
这篇关于java - 在并发的情况下,程序事务和数据库事务是怎么运行的?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文