• Spring对Hibernate事务管理的简单理解


    在 谈Spring事务管理之前我们想一下在我们不用Spring的时候,在Hibernate中我们是怎么进行数据操作的。在Hibernate中我们每次 进行一个操作的的时候我们都是要先开启事务,然后进行数据操作,然后提交事务,关闭事务,我们这样做的原因是因为Hibernate默认的事务自动提交是 false,他是需要我们人为的手动提交事务,假如你不想每次都手动提交事务的话,你可以在hibernate.cfg.xml我文件中把它设置为事务自 动提交:

    <property name="hibernate.connection.autocommit">true</property> 
    

    当 我们Spring对我们的Hibernate进行整合之后,我们的代码又出现了什么变化呢?整合,之后,我们不再是每次都去拿Session进行数据操作 了,也不需要每次都开启事务,提交事务了,我们只需要Spring给我们提供的一个HibernateTemplate,我们直接用这个类里面给我们提供 的数据操作方法就可以操作数据了。我们在也看不到关于事务的代码了,那Spring究竟有没有在他的操作方法里面封装事务处理呢?有的人直接 HibernateTemplate里面提供的方法操作数据,成功了,有的人却又失败了,这到底是怎么回事呢?其实这里要看我们是怎样集成我们的 Hibernate和Spring,如果在集成的过程中,我们抛弃了hibernate.cfg.xml文件,直接在Spring的的配置文件中进行配置 数据源的话,那你直接用HibernateTemplate里面提供的方法是可以成功操作数据的,如果你还是用hibernate.cfg.xml来配置 数据源,在Spring的配置文件中引用hibernate.cfg.xml文件,那么你不能成功,这其中的原因就是因为如果你用 hibernate.cfg.xml文件配置数据源,就像我们前面说的,Hibernate默认是手动提交事务,而HibernateTemplatel 提供的方法里面并没有提供事务提交,而如果你用Spring的配置文件来配置数据源,Sping默认是自动提交的,所以就会成功,如果你想把Spring 设置为手动提交你可以在起配置文件中进行配置:

    <property name="defaultAutoCommit">
    	<value>false</value>
    </property> 
    

    纵 然我们把它的事务提交方式设置为自动,它可以进行数据操作,但是这样并不满足我们实际的业务需求,因为有时候在我保存一个数据之后,我希望他能继续保存另 一条数据,我希望在保存完两条或者多条之后一起进行事务提交,这样即使出错,我们可以回滚,取保数据的一致性,要么都成功要么都失败,这时候我们就不能每 保存完一条数据之后事务就自动提交,因为这样它们不在同一个事务当中,我们不能保证数据的一致行。所以这时候我们就需要手动的来配置我们的事务,这就需要 用到Spring为Hibernate提供的事务管理机制,Spring提供的事务管理可以分为两类:编程式的和声明式的,编程式,其实就是在代码里面来 控制,像Hibernate操作数据一样,开启事务,提交事务,这种方式有一定的局限性,所以我们一般是用声明式来配置我们的事务。

    声明式事务配置主要分以下几步:

    1、声明式事务配置

    • 配置事务管理器;
    • 事务的传播特性;
    • 那些类那些方法使用事务。
    <!-- 配置事务管理器 指定其作用的sessionFactory把事务交给Spring去处理 -->
    
    	<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    	<property name="sessionFactory">
    	<ref bean="sessionFactory"/>
    	</property>
    	</bean>
    
    <!-- 配置事务的传播特性 -->
    	<tx:advice id="txAdvice" transaction-manager="transactionManager">
    	<tx:attributes>
    	<tx:method name="save*" propagation="REQUIRED"/>
    	<tx:method name="delete*" propagation="REQUIRED"/>
    	<tx:method name="update*" propagation="REQUIRED"/>
    	<tx:method name="get*" read-only="true" propagation="NOT_SUPPORTED"/>
    	<tx:method name="*" read-only="true"/>
    	</tx:attributes>
    	</tx:advice>
    
    <!-- 那些类的哪些方法参与事务 -->
    	<aop:config>
    	<aop:pointcut id="allServiceMethod" expression="execution(* com.coe.service.*.*(..))"/>
    	<aop:advisor pointcut-ref="allServiceMethod" advice-ref="txAdvice"/>
    	</aop:config> 
    

    我 们在配置事务的时候,我们一般是把事务边界设置到service层,也就是你的业务逻辑层,因为我们很多时候都是在我们的业务逻辑层来完成我们一些列的数 据操作,如果放到Dao数据层,其粒度太小了。另外,如果我们把事务配置在业务逻辑层的话,对我们的二级缓存也是有好处的,这个大家以后实际操作的时候会 发现。

    2、编写业务逻辑方法

    这 时候我们就可以在我们业务逻辑层用HibernateTemplate里面提供的数据操作方法来编写我们的业务逻辑方法了,当然我们的方法必须要是以我们 事务配置里面配置的一样,用save,delete,update,get做我们的方法的开头。需要注意的是,默认情况下运行期异常才会回滚(包括继承了 RuntimeException子类),普通异常是不会滚的。

    (转)http://www.cnblogs.com/kevin-yuan/archive/2012/09/19/2693153.html

     

  • 相关阅读:
    co coa ch ina
    提高英语听力最好的学习方法
    http://www.funnygames.us/search/?s=balance
    flash
    https://github.com/search?l=ObjectiveC&p=2&q=cocos&ref=searchbar&type=Repositories
    game.m https://github.com/kayrules/Cocos2dEndlessPlatformerGame
    2013年下半年学习计划
    Javascript判断数据类型
    vue组件自定义属性命名
    BZOJ 1018 线段树维护连通性
  • 原文地址:https://www.cnblogs.com/yaoxing92/p/3020574.html
Copyright © 2020-2023  润新知