mysql-事务隔离级别极简解释
多事务并发进行容易出现的问题
- 脏写: 我写的时候,你也可以写。
- 脏读: 我写的时候,你可以读。
- 不可重复读:我读的时候,你可以写。
- 幻读: 我读的时候,你可以修改其他记录。
- 说明:我和你是2个并发运行的数据库事务,针对的是DB里同一个数据,比如同一行的同一个字段。
如何避免上述问题
- 脏写一般关系型数据库都可以避免。
- 脏读:READ COMMITTED,只能读事务提交后的数据,比如A事务把name字段从 张三 修改成 李四,但是事务没有提交,这时你用SELECT 语句读到的还是张三。
- 不可重复读: REPEATABLE READ, 我开启一个事务,读了Student表中的1条记录,只要我这事务没提交,要保证我重新读取这条记录时数据不能发生变化。
- 幻读: SERIALIZABLE, 我开启一个事务,用where条件过滤出的结果是5条记录,只要我这事务没提交,要保证我下次用相同where条件时过滤出的还是这相同的5条记录,不能是其它记录。
如何保证
- 使用MVCC 和 数据库锁,这是另外一个主题了,下回分解。
作者:imap
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
2013-10-18 jquery中的ajax应用集锦