事务的四个隔离级别离别有哪些
事务的四个隔离级别离别是:1、读取未提交内容(Read Uncommitted);2、读取提交内容(Read Committed);3、可重读(Repeatable Read);4、可串行化(Serializable)。
事务的四个隔离级别:
(引荐学习:mysql教程)
一、Read Uncommitted -- 读取未提交内容
一个事务可以查看到未提交的内容
常发生脏读问题(脏读:读取到其他事务未提交(施行)的内容)
对统一数据表开启A、B两个事务(A、B事务穿插) start transaction
A事务只查询数据表中内容,B事务做增删改操纵但不commit(提交)
A事务照旧可以查询到表中的数据改动(查询到未提交的内容--脏读)
二、Read Committed -- 读取提交内容
一个事务只能查看已提交的内容
常发生不成反复读的问题(不成反复读:统一事务中施行雷同的select语句得到不一样的结果)
对统一数据表开启A、B两个事务(A、B事务穿插) start transaction
A事务只查询数据表中内容,B事务做增删改操纵但不commit(提交)
A事务查询不到表中的数据改动的内容
B事务提交
A查到的数据改动(A两次查询,发生不一样的结果--不成反复读)
三、Repeatable Read -- 可重读
统一事务的多个实例并发读取数据时得到统一结果
MySQL的默许事务隔离级别
常发生幻读问题(幻读:屡次读取时发生不一样结果(幻影行))
对统一数据表开启A、B两个事务(A、B事务穿插) start transaction
A事务只查询数据表中内容,B事务做增删改操纵但不commit(提交)
A事务查询不到表中的数据改动的内容
B事务提交
A事务查询不到表中的数据改动的内容
A提交
A可查询到表中数据的改动
四、Serializable -- 可串行化
最高隔离级别
给事务加上同享锁,同时只能有一个事务操纵,解决幻读问题
会致使大量超时和锁竞争问题
开启A事务
开启B事务时没法增删该操纵
以上就是事务的四个隔离级别离别是啥的具体内容,更多请关注百分百源码网其它相关文章!