首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

Spring与Hibernate调整-事务的探讨

2012-08-21 
Spring与Hibernate整合--事务的探讨class PersonDaoImpl extends HibernateDaoSupport{public void save(P

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" lazy-init="true"/>
如果想对所有bean都应用延迟初始化,可以在根节点beans设置default-lazy-init=“true“,如下:
<beans default-lazy-init="true" ...>
prototype
每次从容器获取bean都是新的对象

注入依赖对象

基本类型对象注入:
<bean id="orderService" ref="orderDao"/>
</bean>
方式二(使用内部bean,但该bean不能被其他bean使用)
<bean id="orderService" 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属性,就只能按名称装配了。



热点排行