Hibernate中的事务隔离问题(脏读不可重复读幻读)

Posted 渡劫锦官城

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Hibernate中的事务隔离问题(脏读不可重复读幻读)相关的知识,希望对你有一定的参考价值。

Hibernate中的事务隔离问题(脏读、不可重复读、幻读)

1.事务的特性

事务的四个特性:

1)原子性:事务是进行数据库操作的最小单位,所以组成事务的各种操作是不可分割的

2)一致性:组成事务的各种操作,要么全部成功,要么全部失败。其中有一个失败,事务无法完成

3)隔离性:在并发中,每个事务都是独立的

4)持久性:这是结果,表示在事务提交之后,数据将持久的保存到数据库

2.事务的隔离问题

事务的三个隔离问题:

1)脏读:一个事务读到了另一个事务还没提交的数据

如:A事务正在读一个数据a,但是这个数据被B事务读过,但是B事务还未提交。这就导致A事务读到了错误的数据

2)不可重复读:一个事务读到了另一个事务已经提交的数据

如:A事务中有两次相同的读取数据a的操作,第一次对数据a进行了读操作之后,B事务修改了数据a并提交,那么在A事务第二次读取数据a时,就得到了两个不同的结果

3)幻读:像发生了幻觉一样的操作

如:A事务在对一个表中的全部数据进行修改时,B事务向表中插入了一条新的数据,当A事务提交之后,你会发现还有一条数据(就是B事务新增的数据)没被修改。这就像发生了幻觉一样

3.事务的隔离级别

1) Serializable (串行化):可避免脏读、不可重复读、幻读

2) Repeatable read (可重复读):可避免脏读、不可重复读

3) Read committed (读已提交):可避免脏读

4) Read uncommitted (读未提交):最低级别,任何情况都无法保证

以上是关于Hibernate中的事务隔离问题(脏读不可重复读幻读)的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server 中的事务与事务隔离级别以及如何理解脏读, 未提交读,不可重复读和幻读产生的过程和原因

脏读,不可重复读,幻读及事务隔离等级

什么是脏读不可重复读幻读?一文带你搞定MySQL事务隔离级别

何为脏读不可重复读幻读

什么是脏读不可重复读幻读?一文带你快速搞定MySQL事务隔离级别

SQL Server 中的事务与事务隔离级别以及如何理解脏读, 未提交读,不可重复读和幻读产生的过程和原因