一、Isolation Level(事务隔离等级):
1、Serializable:最严格的级别,事务串行执行,资源消耗最大;
2、REPEATABLE READ:保证了一个事务不会修改已经由另一个事务读取但未提交(回滚)的数据。避免了“脏读取”和“不可重复读取”的情况,但是带来了更多的性能损失。
3、READ COMMITTED:大多数主流数据库的默认事务等级,保证了一个事务不会读到另一个并行事务已修改但未提交的数据,避免了“脏读取”。该级别适用于大多数系统。
4、Read Uncommitted:保证了读取过程中不会读取到非法数据。
二、在Spring中定义了5中不同的事务隔离级别(比正常数据库事务隔离多一个):
spring中的Isolation属性:
1、ISOLATION_DEFAULT :使用当前数据源的默认级别
2、ISOLATION_READ_UNCOMMITTED :会产生脏读,不可重复读和幻像读
3、ISOLATION_READ_COMMITTED :可以避免脏读出现,但是可能会出现不可重复读和幻像读
4、ISOLATION_REPEATABLE_READ:可以避免脏读出现,但是可能会出现不可重复读和幻像读
5、ISOLATION_SERIALIZABLE:除了防止脏读,不可重复读外,还避免了幻读.
这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。
三、脏读,不可重复读 ,幻读
1、什么是脏读?(修改且未提交引起)
例如:
张三的工资为5000,事务A中把他的工资改为8000,但事务A尚未提交。与此同时,事务B正在读取张三的工资,读取到张三的工资为8000。随后,事务A发生异常,而回滚了事务。张三的工资又回滚为5000。最后,事务B读取到的张三工资为8000的数据即为脏数据,事务B做了一次脏读。
2、什么是不可重复读?(修改引起) 6 h2 E% J, S7 f9 n+ m0 U4 ]" ?% e. a
例如: / ^7 Y# T6 |& Z' B
在事务A中,读取到张三的工资为5000,操作没有完成,事务还没提交。 5 K: N6 c" [$ p: J4 L/ I" B
与此同时,事务B把张三的工资改为8000,并提交了事务。随后,在事务A中,再次读取张三的工资,此时工资变为8000。在一个事务中前后两次读取的结果并不致,导致了不可重复读。
(大部分数据库缺省的事物隔离级别都不会出现这种状况)
3、什么是幻读?(添加新记录引起) 9 d! D% j. |9 w9 N+ ~
例如:
A目前工资为5000的员工有10人,事务A读取所有工资为5000的人数为10人。此时,事务B插入一条工资也为5000的记录。这是,事务A再次读取工资为5000的员工,记录为11人。此时产生了幻读。
大部分数据库缺省的事物隔离级别都会出现这种状况,此种事物隔离级别将带来表级锁) . h+ U! y9 {) }1 R8 ~% B, l; t