zoukankan      html  css  js  c++  java
  • mysql-事务隔离级别极简解释

    多事务并发进行容易出现的问题

    • 脏写: 我写的时候,你也可以写。
    • 脏读: 我写的时候,你可以读。
    • 不可重复读:我读的时候,你可以写。
    • 幻读: 我读的时候,你可以修改其他记录。
    • 说明:我和你是2个并发运行的数据库事务,针对的是DB里同一个数据,比如同一行的同一个字段。

    如何避免上述问题

    • 脏写一般关系型数据库都可以避免。
    • 脏读:READ COMMITTED,只能读事务提交后的数据,比如A事务把name字段从 张三 修改成 李四,但是事务没有提交,这时你用SELECT 语句读到的还是张三。
    • 不可重复读: REPEATABLE READ, 我开启一个事务,读了Student表中的1条记录,只要我这事务没提交,要保证我重新读取这条记录时数据不能发生变化。
    • 幻读: SERIALIZABLE, 我开启一个事务,用where条件过滤出的结果是5条记录,只要我这事务没提交,要保证我下次用相同where条件时过滤出的还是这相同的5条记录,不能是其它记录。

    如何保证

    • 使用MVCC 和 数据库锁,这是另外一个主题了,下回分解。
    作者:imap
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
  • 相关阅读:
    关于文件路径的生成
    re模块小结
    logging模块知识点及应用小结
    微信小程序上传图片
    小程序图表插件
    小程序实现多图上传、预览
    微信小程序实现验证码倒计时效果
    微信小程序上传图片,视频及预览
    小程序实现星级打分
    小程序获取系统日期时间
  • 原文地址:https://www.cnblogs.com/imap/p/15419133.html
Copyright © 2011-2022 走看看