`

Spring与Hibernate整合--事务的探讨

阅读更多
class PersonDaoImpl extends HibernateDaoSupport
{  
public void save(Person person) throws Exception {
  //下面这行代码能看到回卷事务的效果
  this.getHibernateTemplate().save(person);
  //下面这行代码没有回卷的效果了,在spring整合的hibernate中,session每次都是自动提交事务。
  //this.getSessionFactory().openSession().save(person); 
  int x = 3/0;
}
}

以上面代码为例,如果用的是Spring提供的Hibernate模板来保存,那么默认是开启事务的。在发生异常时,就会回滚事务。
但是若我们不使用Spring的模板,而是自己开启一个Session进行保存。这时和Hibernate的默认设置不同,Hibernate默认是不自动提交事务的,而交给Spring管理后,默认为每次都自动提交事务了。

因此,在Spring与Hibernate整合的项目中,应该都使用Spring提供的模板进行数据操作。才能有效的进行事务管理。

=========
Bean的作用域

singleton
在每个Spring IoC容器中一个bean定义只有一个对象实例。默认情况下会在容器启动时初始化bean,但我们可以指定Bean节点的lazy-init=“true”来延迟初始化bean,这时候,只有第一次获取bean会才初始化bean。如:
<bean id="xxx" class="cn.itcast.OrderServiceBean" lazy-init="true"/>
如果想对所有bean都应用延迟初始化,可以在根节点beans设置default-lazy-init=“true“,如下:
<beans default-lazy-init="true" ...>
prototype
每次从容器获取bean都是新的对象

注入依赖对象

基本类型对象注入:
<bean id="orderService" class="cn.itcast.service.OrderServiceBean">
<constructor-arg index=“0” type=“java.lang.String” value=“xxx”/>//构造器注入
<property name=“name” value=“zhao/>//属性setter方法注入
</bean>

注入其他bean:
方式一
<bean id="orderDao" class="cn.itcast.service.OrderDaoBean"/>
<bean id="orderService" class="cn.itcast.service.OrderServiceBean">
<property name="orderDao" ref="orderDao"/>
</bean>
方式二(使用内部bean,但该bean不能被其他bean使用)
<bean id="orderService" class="cn.itcast.service.OrderServiceBean">
<property name="orderDao">
  <bean class="cn.itcast.service.OrderDaoBean"/>
</property>
</bean>

<bean id="order" class="cn.itcast.service.OrderServiceBean">
    <property name="lists">
          <list>
<value>lihuoming</value>
         </list>
      </property> 
      <property name="sets">
         <set>
            <value>set</value>
        </set>
      </property> 
     <property name="maps">
        <map>
            <entry key="lihuoming" value="28"/>
       </map>
     </property> 
     <property name="properties">
        <props>
<prop key="12">sss</prop>
       </props>
      </property>
</bean>

以上的装配方式为XML文件方式。如果用的是注解方式。则按以下步骤:

在java代码中使用@Autowired或@Resource注解方式进行装配。但我们需要在xml配置文件中配置以下信息:
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-2.5.xsd">
          <context:annotation-config/>
</beans>
在java代码中使用@Autowired或@Resource注解方式进行装配,这两个注解的区别是:@Autowired 默认按类型装配,@Resource默认按名称装配,当找不到与名称匹配的bean才会按类型装配。
    @Autowired
    private PersonDao  personDao;//用于字段上
    @Autowired
    public void setOrderDao(OrderDao orderDao) {//用于属性的setter方法上
        this.orderDao = orderDao;
    }
@Autowired注解是按类型装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。如下:
    @Autowired  @Qualifier("personDaoBean")
    private PersonDao  personDao;

@Resource注解和@Autowired一样,也可以标注在字段或属性的setter方法上,但它默认按名称装配。名称可以通过@Resource的name属性指定,如果没有指定name属性,当注解标注在字段上,即默认取字段的名称作为bean名称寻找依赖对象,当注解标注在属性的setter方法上,即默认取属性名作为bean名称寻找依赖对象。
    @Resource(name=“personDaoBean”)
    private PersonDao  personDao;//用于字段上

注意:如果没有指定name属性,并且按照默认的名称找不到依赖对象时, @Resource注解会回退到按类型装配。但一旦指定了name属性,就只能按名称装配了。



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics