事务的四个特性

一、原子性
    原子性指事务包含的所有操作要么全部成功,要么全部失败回滚。因此事务的成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。

二、一致性
    一致性是指事务必须使数据库从一个致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。一致性的必须通过原子性来实现,同时还需要逻辑的正确,保证数据的守恒。

三、隔离性
    隔离性是指多个并发事务之间相互隔离,数据库为每个用户开启的事务不能被其他事务的操作所干扰。

    数据库的隔离级别从高到低分为:

  1. Serializable(串行化):读加共享锁(读锁),写加排他锁。这样读取可以并发,但是读写、写写事务之间都是互斥的,基本都是一个个串行的执行事务,所以叫串行化。级别最高,执行的效率也最低。
  2. Repeatable read(可重复读):读事务会阻止其他写事务,但不会阻止其他读事务。
    存在的问题:幻读。可重复读阻止的写事务包括update和delete(只给存在的表加上了锁),但不包括insert,所以多次读取的记录数可能不一样。mysql数据库默认的隔离级别。
  3. Read committed(可读取确认):写事务会阻止其他读写事务。读事务不会阻止其他任何事务。
    存在的问题:不可重复读。即一次事务之间,进行了两次读取,但是结果不一致。大部分主流数据库默认的隔离级别。
  4. Read uncommitted(可读取未确认):写事务阻止其他写事务,但是没有阻止其他读事务。
    存在的问题:脏读。即读取到不正确的数据,如果一个事务还未提交最终数据,另一个读事务读取了中途的数据,这个数据可能是不正确的。

四、持久性
    持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。

你可能感兴趣的:(数据库,事务)