事务

  • Transaction
  • 在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。
  • 原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性。
  • 狭义上的事务特指数据库事务。一方面,当多个应用程序并发访问数据库时,事务可以在这些应用程序之间提供一个隔离方法,以防止彼此的操作互相干扰。

特性

  • 原子性(Atomicity)
    原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

  • 一致性(Consistency)
    事务前后数据的完整性必须保持一致。

  • 隔离性(Isolation)
    事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。

  • 持久性(Durability)
    持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响

事务隔离级别

  • 脏读:
    指一个事务读取了另外一个事务未提交的数据。

  • 不可重复读:
    在一个事务内读取表中的某一行数据,多次读取结果不同。(这个不一定是错误,只是某些场合不对)

  • 虚读(幻读)
    是指在一个事务内读取到了别的事务插入的数据,导致前后读取数量总量不一致。
    (一般是行影响,如下图所示:多了一行)

更详细:https://www.cnblogs.com/songanwei/p/9387526.html