`

hibernate 事务解析

阅读更多

数据库ACID特征:
A. Atomic(原子性):指整个数据库事务是不可分割的工作单元。

B. Consistency(一致性):指数据库事务不能破坏关系数据的完整性以及业务逻辑上的一致性。

C. Isolation(隔离性):指的是在并发环境中,当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间。

D. Durability(持久性):指的是只要事务成功结束,它对数据库所作的更新就必须永久保存下来。

 

并发引起的问题:

A. 第一类丢失更新:撤销一个事务时,把其他事务已提交的更新数据覆盖。

B. 脏读:一个事务读到另一个事务未提交的更新数据。 (更新数据时发生

C. 幻像读:一个事务读到另一个事务已提交的新插入的数据。 (添加或删除数据时发生

D. 不可重复读:当事务1读取了一条记录,该记录为事务2未提交事务记录中,事务2修改了该条记录并且提交事务;事务1又读取了该条记录,发现两条记录不一样。 (修改数据时发生

E. 第二类丢失更新:这是不可重复读中的特例,一个事务覆盖另一个事务已提交的更新数据。


数据库系统提供了四种事务隔离级别供用户选择:

A. Serializable(串行化):一个事务在执行过程中完全看不到其他事务对数据库所做的更新。 实际上是独占方式读取数据。

B. Repeatable Read(可重复读):一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,但是不能看到其他事务对已有记录的更新。 锁定查询中使用的所有数据以防止修改(避免脏读和不可重复读),但是不防止插入数据,这时重新读取时,就会读到之前没读到的数据,出现了幻读。此隔离级别允许出现幻读。

C. Read Commited(读已提交数据):一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,而且能看到其他事务已经提交的对已有记录的更新。

D. Read Uncommitted(读未提交数据):一个事务在执行过程中可以看到其他事务没有提交的新插入的记录,而且能看到其他事务没有提交的对已有记录的更新。

隔离级别

脏读

不可重复读

幻读

读未提交  

读已提交

可重复读

可序列化

 

 

hibernate锁可以分为以下几类:

1.悲观锁

它指的是对数据被外界修改持保守态度。假定任何时刻存取数据时,都可能有另一个客户也正在存取同一笔数据,为了保持数据被操作的一致性,于是对数据采取了数据库层次的锁定状态,依靠数据库提供的锁机制来实现。
基于jdbc实现的数据库加锁如下:

select * from account where name="Erica" for update

在更新的过程中,数据库处于加锁状态,任何其他的针对本条数据的操作都将被延迟。本次事务提交后解锁。
而hibernate悲观锁的具体实现如下:

String sql="查询语句";Query query=session.createQuery(sql);query.setLockMode("对象",LockModel.UPGRADE);


hibernate的加锁模式:

LockMode.NONE:无锁机制。
LockMode.WRITE:Hibernate在Insert和Update记录的时候会自动获取。
LockMode.READ:Hibernate在读取记录的时候会自动获取。

这三种加锁模式是供hibernate内部使用的,与数据库加锁无关:

LockMode.UPGRADE:利用数据库的for update字句加锁。

在这里我们要注意的是:只有在查询开始之前(也就是hiernate生成sql语句之前)加锁,才会真正通过数据库的锁机制加锁处理。否则,数据已经通过不包含for updata子句的sql语句加载进来,所谓的数据库加锁也就无从谈起。
但是,从系统的性能上来考虑,对于单机或小系统而言,这并不成问题,然而如果是在网络上的系统,同时间会有许多联机,假设有数以百计或上千甚至更多的并发访问出现,我们该怎么办?如果等到数据库解锁我们再进行下面的操作,我们浪费的资源是多少?--这也就导致了乐观锁的产生。

2.乐观锁

乐观锁定(optimistic locking)则乐观的认为资料的存取很少发生同时存取的问题,因而不作数据库层次上的锁定,为了维护正确的数据,乐观锁定采用应用程序上的逻辑实现版本控制的方法。

 

乐观锁大多是基于数据版本(Version)记录机制实现。Hibernate在其数据访问引擎中内置了乐观锁实现,可以通过class描述符的optimistic-lock属性结合version描述符指定。optimistic-lock属性有如下可选取值:
      1. none:无乐观锁
      2. version:通过版本机制实现乐观锁
      3. dirty:通过检查发生变动过的属性实现乐观锁
      4. all:通过检查所有属性实现乐观锁

分享到:
评论

相关推荐

    Hibernate源码解析(二)

    通过源码级别的分析,我们可以洞察到Hibernate如何将Java对象与数据库表进行映射,以及它如何执行SQL查询和事务管理。 一、对象关系映射(ORM) Hibernate作为ORM工具,其主要任务是消除Java应用与关系数据库之间...

    Hibernate源码解析(一)

    《Hibernate源码解析(一)》 在Java开发领域,Hibernate作为一款强大的对象关系映射(ORM)框架,极大地简化了数据库操作。深入理解Hibernate的源码,不仅可以帮助开发者更好地运用该工具,还能提升对Java编程和...

    Hibernate源码解析(三)

    源码解析可能会揭示`Session`内部的事务管理、缓存机制以及如何封装JDBC操作。 其次,`SessionFactory`的创建过程也是一个重要的知识点。`SessionFactory`是Hibernate的工厂类,用于创建`Session`实例。它的创建...

    spring mvc+hibernate实现事务管理(配置文件版)

    本项目是关于如何使用Spring MVC与Hibernate结合来实现事务管理的实践教程,通过MyEclipse自动生成所需的包和配置文件。这里将详细讲解这一过程,以及涉及到的关键知识点。 首先,Spring MVC作为Spring框架的一部分...

    Hibernate原理解析

    **Hibernate原理解析** Hibernate是一个开源的Java语言下的对象关系映射(ORM)框架,它为开发者提供了在Java应用程序中操作数据库的强大工具。通过Hibernate,开发者可以将数据库操作与业务逻辑解耦,使得代码更加...

    spring 结合druid和hibernate使用jta配置分布式事务

    本篇将详细讲解如何在Spring环境中结合Druid数据源和Hibernate ORM框架,利用Atomikos实现JTA(Java Transaction API)来配置分布式事务。 首先,`Spring` 是一个开源的应用框架,它提供了AOP(面向切面编程)和DI...

    Spring AOP管理Hibernate事务(TransactionInSpringAOP)

    结合给出的标签"源码"和"工具",我们可以进一步理解,本文可能会深入到源码层面解析Spring AOP和Hibernate事务管理的实现原理,或者提供一些实用的工具或技巧来帮助开发者更好地管理和调试事务。 通过阅读博文...

    hibernate源码分析

    综上所述,Hibernate源码分析涵盖了从配置解析、对象持久化、事务管理到高级特性的实现细节。通过对这些内容的深入理解,开发者可以更好地利用Hibernate,同时也能提升对ORM框架及数据库操作的理解。在实际开发中,...

    hibernate的事务核并发

    ### Hibernate事务管理 #### 非托管环境下的事务处理 在非托管环境中,如独立的Java应用程序或Web应用中,Hibernate通过其内部的连接池机制管理数据库连接。为了执行事务操作,开发者需要遵循以下步骤: 1. **...

    hibernate缓存解析

    【hibernate缓存解析】 Hibernate缓存是其性能优化的关键所在,它位于Hibernate应用与数据库之间,存储了数据库数据的副本,目的是减少对数据库的访问次数,从而提高应用程序的运行效率。缓存机制分为一级缓存和二...

    Hibernate最详细的讲解

    **Hibernate 知识点详解** Hibernate 是一个开源的 Object-Relational Mapping (O/R Mapping) 框架,它提供了一种在 Java 应用程序中管理关系数据库模型的便捷方式。通过 Hibernate,开发者可以将数据库操作转化为...

    spring3+hibernate4声明式事务配置(xml方式)

    Spring3和Hibernate4的集成可以帮助开发者实现高效、灵活的持久化层管理,并通过声明式事务管理来保证数据的一致性。本教程将深入探讨如何使用XML配置来设置Spring3和Hibernate4的声明式事务管理。 首先,我们需要...

    Hibernate开发实战讲解(源代码)源码整理

    《Hibernate开发实战讲解》源码解析 在Java领域,Hibernate是一个非常重要的持久化框架,它极大地简化了数据库操作,使得开发者能够专注于业务逻辑而非繁琐的数据交互。本篇将深入探讨Hibernate的核心概念,以及...

    Struts + Spring + Hibernate工作原理解析

    Struts、Spring和Hibernate是Java开发中非常著名的三个开源框架,它们共同构成了经典的"SSH...通过阅读《Struts + Spring + Hibernate工作原理解析》文档,你可以更系统地掌握这些知识,为你的项目开发带来极大的帮助。

    Hibernate part 14:查询及数据库并发事务

    **标题解析:**“Hibernate part 14:查询及数据库并发事务” 这个标题指出我们要讨论的是Hibernate框架在处理查询和数据库并发事务方面的内容。Hibernate是一个流行的Java对象关系映射(ORM)工具,它允许开发者...

    精通hibernate源码ch5

    我们将学习如何在Hibernate中配置和使用事务,以及事务的隔离级别和回滚规则。 六、查询语言HQL与Criteria API Hibernate提供了面向对象的查询语言HQL(Hibernate Query Language)和Criteria API,它们允许开发者...

    hibernate+spring配置详细解析

    本文详细介绍了Hibernate与Spring集成过程中涉及的关键配置,包括数据源、SessionFactory、事务管理器以及事务代理工厂的配置细节。通过这些配置,可以实现对数据库的高效访问,并利用Spring的事务管理机制来简化...

    hibernate 执行原生sql的几种方式

    在Java的持久化框架...在使用原生SQL时,需要注意数据库兼容性、事务管理和结果集映射等问题。在大多数情况下,应尽量利用Hibernate的ORM能力,但在处理特定数据库特性和性能优化时,原生SQL是不可或缺的工具。

    springmvc-spring-hibernate 源码

    总之,这个项目展示了如何集成Spring MVC、Spring和Hibernate来构建一个完整的Java Web应用,涉及到的主要知识点包括:Spring MVC的请求处理机制、Spring的依赖注入和事务管理、Hibernate的ORM映射和分页查询。...

Global site tag (gtag.js) - Google Analytics