文章详情页
数据库 - mysql如何处理数据变化中的事务?
浏览:208日期:2022-06-14 13:16:41
问题描述
有以下两个事务同时commit:A: 读取余额,减掉50,提交更新数据库B: 读取余额,加上50,提交数据库
假设A,B两事务同时提交,mysql如何保证最终结果正确?mysql默认隔离级别为可重复读,那么就有可能A读到余额100元,然后更新到50;此时B执行,B执行完成。此时库为150;A再提交的话就成了50,B的更新被覆盖。。我的这个理解方式哪里有问题?mysql如何解决这个问题?
问题解答
回答1:事务这块在程序控制,一般不要数据库自己的事务机制
回答2:select for update,上锁,效果就是A或B其中一个读了余额,另外一个等待锁读不了余额,也就不会有后续的并发写。
回答3:你这个不属于事务,事务是用来处理多个事件的添删改
而你这个属于并发。。。
只是修改一条数据,不需要使用事务,像你说的同时就会耗性能
相关文章:
1. spring-mvc - spring-session-redis HttpSessionListener失效2. android glide asbitmap 在baseadpter中的问题3. docker gitlab 如何git clone?4. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?5. python - flask post提交timestamp不能作为参数,这是为什么?6. 前端 - @media query 使用出现的问题?7. java - Spring boot 读取 放在 jar 包外的,log4j 配置文件,系统有创建日志文件,不写入日志信息。8. javascript - 如何获取未来元素的父元素在页面中所有相同元素中是第几个?9. jquery - js向两边展开10. linux - redis连接池应用在一万并发下时连接数只有2?
排行榜

网公网安备