四种数据库隔离级别如下所示:
1.READ-UNCOMMITTED(读取未提交内容)
由于在该隔离级别下即使事务未提交所做的修改也会对其他事务产生影响。所以该级别会出现数据脏读的发生。脏读:一个事务读取了另一个未提交的并行事务写的数据。
举例:老板给员工发工资,老板开启事务,然后想员工的账户转钱10000元。此时员工开启事务,查看账户余额发现多了10000元,然后提交事务。但是老板发现转多了,于是修改为转5000元,然后提交事务。最终员工账户多5000元而不是10000元,所以之前员工看到的10000元是脏数据。
2. READ-COMMITTED(读取提交内容)
在该隔离级别下事务没有提交是不会对其他事务产生影响的,只有提交的事务才会影响其他事务。所以避免了读脏数据。但是该级别会出现两次读取数据库数据不一致的情况(不可重复读)。
不可重复读:一个事务重新读取前面读取过的数据,发现两次读取数据不一样(该数据已经被另一个已提交的事务修改过)。
举例:老板给员工发工资。老板开启事务,然后向员工的账户里面转钱一万元,暂不提交事务。员工此时开启事务,查看账户余额,发现账户余额是0元,即老板尚未转钱。紧接着老板提交事务。然后员工觉得不对劲又查看了一次(员工的事务尚未提交),发现现在余额是一万元。即员工同一事务下两次相同查看操作得到的结果不一致。
3. REPEATABLE-READ(可重复读)在该隔离级别下两个事务同时进行,其中一个事务修改数据不会对另一个事务造成影响,即使修改的事务已经提交也不会对另一个事务造成影响。因此,该隔离级别不会出现不可重复读的情况。但是,该级别下会出现幻读。
幻读:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户 发现表中还有没有修改的数据行,就好象发生了幻觉一样.
举例:目前分数为90分以上的的学生有15人,事务A开启,并读取所有分数为90分以上的的学生人数,发现有15人,暂不提交事务。此时,事务B开启,并插入一条分数为99的学生记录,然后提交事务。此时,事务A再次读取90分以上的的学生,发现记录为16人,多了一个人。此时产生了幻读。
4.SERIERLIZED(可串行化)该事务隔离级别最严厉,在进行查询时就会对表或行加上共享锁,其他事务对该表将只能进行读操作,而不能进行写操作。
原文:http://www.cnblogs.com/liuleicode/p/5796642.html