logo资料库

spring事物的7大传播机制,5个隔离机制.docx

第1页 / 共2页
第2页 / 共2页
资料共2页,全文预览结束
spring 事物的七大传播机制与五个隔离级别(简易版) 一、spring 事务的传播机制(HibernateTransactionManager) 1.如果当前没有事务,就新建一个事务;如果已存在一个事务,就加入到这 个事务中。 2.支持当前事务,如果当前没有事务,以非事务方式执行。 3.使用当前事务,如果当前没有事务,则抛出异常。 4.新建事务,如果当前存在事务,则把当前事务挂起。 5.以非事务方式执行,如果当前存在事务,则把当前事务挂起。 6.以非事务方式执行,如果当前存在事务,则抛出异常。 7.如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与 1. 类似的操作。 二、spring 事务隔离级别(Isolation Level) ISOLATION_DEFAULT 这是一个 PlatfromTransactionManager 默认的隔离级别,使用数据库默认的事务 隔离级别. 另外四个与 JDBC 的隔离级别相对应; ISOLATION_READ_UNCOMMITTED (未提交读) 这是事务最低的隔离级别,它充许别外一个事务可以看到这个事务未提交的数 据。 这种隔离级别会产生脏读,不可重复读和幻像读。 ISOLATION_READ_COMMITTED 保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取 该事务未提交的数据。 这种事务隔离级别可以避免脏读出现,但是可能会出现不可重复读和幻像读。 (提交读) ISOLATION_REPEATABLE_READ 这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。 (可重复读)
它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情 况产生(不可重复读)。 ISOLATION_SERIALIZABLE (序列化) 这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。 除了防止脏读,不可重复读外,还避免了幻像读。 ======================================================================== ================ 脏读:指一个事务读取了一个未提交事务的数据 不可重复读:在一个事务内读取表中的某一行数据,多次读取结果不同.一个事务读 取到了另一个事务提交后的数据. 虚读(幻读):在一个事务内读取了别的事务插入的数据,导致前后读取不一致 (insert) ======================================================================== ================ 五个隔离级别: 脏不幻(金不换) 第一个是数据库默认 第二个会出现:脏读、不可重复读、幻读 第三个会出现:不可重复读、幻读 第四个会出现:幻读 第五个全部都不会出现 --------------------- 本文来自 我是小袋子 的 CSDN 博客 ,全文地址请点击: https://blog.csdn.net/z654893465/article/details/81291362?utm_source=cop y
分享到:
收藏