数据库--事务

1、什么是事务?

  事务是逻辑上的一组操作,要么都执行,要么都不执行。

2、事务的四大特性

  1)原子性(Atomicity):事务是最小的执行单位,不允许分割。事务的原子性确保动作全部完成,要么完全不起作用。

  2)一致性(Consistency):执行事务前后,数据保持一致,多个事务对同一个数据读取的结果是相同的。

  3)隔离性(Isolation):并发访问数据库时,一个用户的事务不被其他事务所干扰,各并发事务之间数据库是独立的。

  4)持久性(Durability):一个事务被提交后。它对数据库中数据的改变是持久的,即使数据库故障也不应该有任何影响。

  

3、并发事务会带来哪些问题:

  1)脏读(Dirty Read):一个事务正在访问数据并对数据进行修改,修改还没有提交到数据库,这是另外一个事务访问了这个数据,然后使用了这个数据。这个数据更改之前的数据,另一个事务读到的数据是“脏数据”,依靠“脏数据”所做的操作是不正确的。

  2)丢失修改(Lost to modify):一个事务读取一个数据时,另外一个事务也访问了该数据,在第一个事务中修改数据后,第二个事务也修改了这个数据。第一个事务内的修改结果丢失,因此称作丢失修改。例如事务1读取某表中的数据 A=20 ,事务2也读取A=20,事务1修改A=A-1,事务2也修改A=A-1,最终结果A=19,事务1的修改丢失。

  3)不可重复读(Unrepeatable read):在一个事务内多次读同一个数据在这个事务还没有结束时,另一个事务也访问该数据。在第一个事务的两次读之间,另一个事务可能已经修改了数据,导致两次读取的数据可能不太一样。

  4)幻读(Phanatom read):幻读与不可重复读类似。发生在一个事务读了几行数据,接着另一个并发 事务插入了一些数据。在随后的查询中第一个事务就会发现多了一些原本不存在的记录,好像发生了幻觉。

  不可重复读与幻读区别:不可重复读--多次读取数据发现某些列的值被修改。幻读--多次读取数据发现记录变少或者变多。

  总结:脏读:事务读取到还没来得及修改的数据;丢失修改:多个事务修改同一数据,后面的修改会覆盖掉前面的修改。不可重复读:多次访问一个数据,中间有事务修改数据导致数据不一致;幻读:多次查询记录,中间有事务删除或者增加了记录,导致了记录不一致。

  

4、事务隔离级别有哪些?MySQL默认隔离级别是?

  SQL标准定义了四个隔离级别:

  1)READ-UNCOMMITTED(读取未提交):最低的隔离级别,允许读取未提交的数据变更,可能导致脏读、幻读或不可重复读。

  2)READ-COMMITTED(读取已提交):允许并发事务读取已经提交的数据,可以阻止脏读,幻读或不可重复读仍可能发生。

  3)REPEATABLE-READ(可重复读):对同一字段的多次读取结果都是一致的,除非是数据本身被事务自己修改,可以组织脏读和不可重复读,幻读仍可能发生。

  4)SERIALIZABLE(可串行化):最高的隔离级别。所有事务依次执行。

 MySQL InnoDB 存储引擎默认支持隔离级别是可重复读。InnoDB 存储引擎在 REPEATABLE-READ(可重复读)事务隔离级别下使用的是 Next-Key Lock锁算法,可以避免幻读的产生。因此InnoDB的可重复读达到了SQL标准的SERIALIZABLE(可串行化)隔离级别。

参考:https://snailclimb.gitee.io/javaguide/#/docs/database/MySQL

  

猜你喜欢

转载自www.cnblogs.com/hoo334/p/12422227.html
今日推荐