hibernete使用手记

1.Could not initialize proxy - the owning Session was closed.

分析原因:
由于Spring控制的Hibernate的生命周期只针对数据层和服务层,而未管理到表现层,所以会出现the owning Session was closed的现象。针对这一点,我通过hibernate filter的方式来解决。

解决方法:
在web.xml中配置filter来解决。

xml 代码
  1. <filter>    
  2.    <filter-name>hibernateFilter <filter-name>    
  3.    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter   
  4.    <filter-class>    
  5.   <filter >    
  6.     
  7.  <filter-mapping>    
  8.    <filter-name> hibernateFilter<filter-name>    
  9.    <url-pattern> *.do <url-pattern>    
  10.   <filter-mapping>   

2. org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.NEVER) - turn your Session into FlushMode.AUTO or remove 'readOnly' marker from transaction definition
错误原因:
OpenSessionInViewFilter在getSession的时候,会把获取回来的session的flush mode 设为FlushMode.NEVER。然后把该sessionFactory绑定到TransactionSynchronizationManager,使request的整个过程都使用同一个session,在请求过后再接除该sessionFactory的绑定,最后closeSessionIfNecessary根据该session是否已和transaction绑定来决定是否关闭session。在这个过程中,若HibernateTemplate 发现自当前session有不是readOnly的transaction,就会获取到FlushMode.AUTO Session,使方法拥有写权限。
也即是,如果有不是readOnly的transaction就可以由Flush.NEVER转为Flush.AUTO,拥有insert,update,delete操作权限,如果没有transaction,并且没有另外人为地设flush model的话,则doFilter的整个过程都是Flush.NEVER。所以受transaction保护的方法有写权限,没受保护的则没有。
参考文章:
  http://calvin.blog.javascud.org/post/46.htm
解决办法:
  采用spring的事务声明,使方法受transaction控制
<bean id="baseTransaction"></bean><bean class="org.springframework.orm.hibernate3.HibernateTransactionManager" id="hibernateTransactionManager"></bean>

  1. <bean id="hibernateTransactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">  
  2.         <property name="sessionFactory">  
  3.             <ref bean="sessionFactory"/>  
  4.         property>  
  5.     bean>  
  6.        
  7.     <bean id="baseTransaction"    
  8.         class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"    
  9.           abstract="true">    
  10.         <property name="transactionManager" ref="hibernateTransactionManager"/>    
  11.         <property name="proxyTargetClass" value="true"/>    
  12.         <property name="transactionAttributes">    
  13.             <props>    
  14.                 <prop key="get*">PROPAGATION_REQUIRED,readOnlyprop>    
  15.                 <prop key="find*">PROPAGATION_REQUIRED,readOnlyprop>    
  16.                 <prop key="load*">PROPAGATION_REQUIRED,readOnlyprop>    
  17.                 <prop key="save*">PROPAGATION_REQUIREDprop>    
  18.                 <prop key="add*">PROPAGATION_REQUIREDprop>    
  19.                 <prop key="update*">PROPAGATION_REQUIREDprop>    
  20.                 <prop key="remove*">PROPAGATION_REQUIREDprop>  
  21.                 <prop key="delete*">PROPAGATION_REQUIREDprop>  
  22.             props>    
  23.         property>    
  24.     bean>    
  25.        
  26.     <bean id="hibernateTemplate" parent="baseTransaction">    
  27.         <property name="target">  
  28.             <ref bean="hibernateTemplateTarget"/>    
  29.         property>    
  30.     bean>    
  31.        
  32.        
  33.     <bean id="hibernateTemplateTarget" class="org.springframework.orm.hibernate3.HibernateTemplate">  
  34.         <property name="sessionFactory">  
  35.             <ref bean="sessionFactory"/>  
  36.         property>  
  37.     bean>  
xml 代码

 3.Caused by: java.lang.NoClassDefFoundError: antlr/ANTLRException

错误原因:使用hibernate3的时候在执行到session.createquery()的时候,需要antlr-2.7.5H3.jar文件。

4.get()与load()方法区别:

详见:http://www.iteye.com/topic/67686

有的时候使用load的时候,会在getXXX的时候报错。这个时候查看错误堆栈多会定位在getXXX或setXXX。多数是由于load开始生成的代理对象了代理对象。但是实际上该对象在数据库中不存在。

你可能感兴趣的:(spring,bean,Hibernate,xml,orm)