• Mysql(三) mysql事务和隔离级别


    Mysql(三) mysql事务和隔离级别

    事务是由一组SQL语句组成的逻辑处理单元

    事务的特性(ACID)

    • 原子性(Atomicity):事务是不可分割的逻辑单元,事务内的操作要么全部成功,要么全部失败
    • 一致性(Consistent):对于数据而言,事务开始和完成后,必须保持一致状态。
    • 隔离性(Isolation):不同事务之间操作互不影响
    • 持久性(Durable):事务完成后,对数据的操作修改是永久性的。

    如果事务并发操作会导致以下问题:

    1. 更新丢失(Lost Update)或脏写

      事务A和事务B都要对同一条记录修改,如果事务A先提交,事务B再提交,那么事务A提交的数据被覆盖,就是脏写

    2. 脏读(Dirty Reads)

      事务A对一条记录进行修改,但还未提交,此时事务B读到这条被A修改的数据,如果此时事务A回滚,那么这条数据就是脏数据

    3. 不可重复读(Non-Repeatable Reads)

      事务内读取了一条数据,一段时间后(期间另一个事务修改了这条数据并提交),再次读取这条数据,但这条数据发生了改变

    4. 幻读(Phantom Reads)

      事务两次读取数据结果集数量不一致。事务A读取到了事务B提交的新增数据

    隔离级别

    “脏读”、“不可重复读”和“幻读”,其实都是数据库读一致性问题,必须由数据库提供一定的事务隔离机制来解决。

    隔离级别脏读不可重复读幻读
    读未提交(Read uncommitted)可能可能可能
    读已提交(Read committed)不可能可能可能
    可重复读(Repeatable read)不可能不可能可能
    可串行化读(Serializable)不可能不可能不可能
    • 读未提交:可以读到别的事务未提交的数据
    • 读已提交:只可以读到别的事务已提交的数据
    • 可重复读:解决不可重复读,事务开启后,第一次读到数据后面以后读取到的数据是一致的
    • 可串行化读:锁表,事务在读取的时候,其他事务不能新增和修改数据

    常看当前数据库的事务隔离级别:

    select @@transaction_isolation;

    show variables like ‘tx_isolation’;

    mysql默认的隔离级别是可重复读(Repeatable read)

  • 相关阅读:
    CSDN编程竞赛·第六期-赛后感受
    【原创】FFMPEG录屏入门指南
    NumPy数组与矩阵(一)
    入手瑞芯微RK3588
    LeetCode 周赛 345(2023/05/14)体验一题多解的算法之美
    mysql for update是锁表还是锁行
    02_SpingBoot 入门案例
    Jakob Jenkov 个人博客 JCE 部分(译文)
    Metasploit使用指南
    docker网络
  • 原文地址:https://blog.csdn.net/l577125882/article/details/125594749