• 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)

  • 相关阅读:
    YOLO v4详解
    C++ALL---
    【spring源码系列】之【FactoryBean类型的接口】
    【西瓜书】6.支持向量机
    Linux网络编程的5种IO模型(三)——多路复用Epoll
    12.反射与动态代理
    【踩坑实录】datax从pg同步数据到hive数据全为null问题
    强大好用的shell:shell的工作原理是什么
    java并发编程
    宠物领养|基于SprinBoot+vue的宠物领养管理系统(源码+数据库+文档)
  • 原文地址:https://blog.csdn.net/l577125882/article/details/125594749