MySQL的事务有四种隔离级别:Read Uncommitted,Read Committed,Repeatable Read,Serializable隔离级别越来越严格
基本有begin,commit,rollback这三条命令
怎么设置数据库的事务隔离级别
语句:
SET TRANSACTION ISOLATION LEVEL <READ COMMITTED>;
事务需要隔离是因为事务并发的时候会出现脏读,不可重复读,幻读的问题
事务的四大特性
数据库事务具有ACID这4个特性:
- A:Atomic,原子性,将所有SQL作为原子工作单元执行,要么全部执行,要么全部不执行;
- C:Consistent,一致性,事务完成后,所有数据的状态都是一致的,即A账户只要减去了100,B账户则必定加上了100;
- I:Isolation,隔离性,如果有多个事务并发执行,每个事务作出的修改必须与其他事务隔离;
- D:Duration,持久性,即事务完成后,对数据库数据的修改被持久化存储。
Read Uncommitted
隔离级别最低的一种事务级别。在这种隔离级别下,一个事务会读到另一个事务更新后但未提交的数据,如果另一个事务回滚,那么当前事务读到的数据就是脏数据,这就是脏读(Dirty Read)
比如事务A进行了更新,但是没有commit,事务B这个时候进行查询,查询的是更新后的数据,然后事务A进行了rollback,事务B在进行查询,查询到的是原始的数据,前后两次查询的数据不一致,这就是脏读
Read Committed
在这种隔离级别下,一个事务可能会遇到不可重复读(Non Repeatable Read)的问题。
不可重复读是指
在一个事务内,多次读同一数据,在这个事务还没有结束时,如果另一个事务恰好修改了这个数据,那么,在第一个事务中,两次读取的数据就可能不一致。
比如事务A,事务B都开始,事务B先进行了一次查询,得到的数据就是原始的数据,然后事务A进行了一次更新,并且提交了,事务B又进行一次查询,得到的数据和第一次又不一样。所以在这种隔离级别下,不可重复读同一条记录
Repeatable Read
在这种隔离级别下,一个事务可能会遇到幻读(Phantom Read)的问题。MySQL默认的事务级别
幻读是指,在一个事务中,第一次查询某条记录,发现没有,但是,当试图更新这条不存在的记录时,竟然能成功,并且,再次读取同一条记录,它就神奇地出现了。
比如一开始数据库中并没有相应的记录,事务B这时候查询这条记录,结果为empty,然后事务A插入了这条记录,并且提交了,然后事务B又开始查询,这时候就可以查询到数据,这就是幻读,而且事务B还可以更新这条记录
至于为什么这种隔离级别就不会出现不可重复读的问题,这是由数据库引擎进行保证的,我们只需要会用的就行了
Serializable
这是最严格的隔离级别。在Serializable隔离级别下,所有事务按照次序依次执行,因此,脏读、不可重复读、幻读都不会出现。
虽然Serializable隔离级别下的事务具有最高的安全性,但是,由于事务是串行执行,所以效率会大大下降,应用程序的性能会急剧降低。如果没有特别重要的情景,一般都不会使用Serializable隔离级别。
各种事务隔离级别并发时会出现的问题

另外,有一篇博文讲的很好:链接
本文深入解析MySQL事务的四大特性(ACID)及四种隔离级别:Read Uncommitted、Read Committed、Repeatable Read、Serializable,探讨各隔离级别下可能出现的脏读、不可重复读、幻读等问题。
5076

被折叠的 条评论
为什么被折叠?



