mysql 事务的理解

  mysql  执行事务操作 

  1.原子性 
    一个事务包含多个操作,这些操作要么全部执行,要么全都不执行。实现事务的原子性,要支持回滚操作,在某个操作失败后,回滚到事务执行之前的状态。
  2.一致性

    执行事务操作,比如转账,两个人互相转账 ,不管转多少次, 钱的总数额是不会改变的。
  3.持久性

     事务提交后,就是对数据库数据的修改保存。
  4.隔离性
      并发事务之间互相影响的程度,比如一个事务会不会读取到另一个未提交的事务修改的数据。

      脏读:事务A修改了一个数据,但未提交,事务B读到了事务A未提交的更新结果,如果事务A提交失败,事务B读到的就是脏数据。
          不可重复读:在同一个事务中,对于同一份数据读取到的结果不一致。比如,事务B在事务A提交前读到的结果,和提交后读到的结果可能不同。不可重复读出现的原因就是事务并发修改记录,要避免这种情况,最简单的方法就是对要修改的记录加锁,这回导致锁竞争加剧,影响性能。另一种方法是通过MVCC可以在无锁的情况下,避免不可重复读。
         幻读:在同一个事务中,同一个查询多次返回的结果不一致。事务A新增了一条记录,事务B在事务A提交前后各执行了一次查询操作,发现后一次比前一次多了一条记录。幻读是由于并发事务增加记录导致的,这个不能像不可重复读通过记录加锁解决,因为对于新增的记录根本无法加锁。需要将事务串行化,才能避免幻读。
     事务的隔离级别从低到高有:

mysql 事务的理解

上一篇:MySQL 8.0.11免安装版配置步骤


下一篇:C#引入SqlLite