注解的方式注入org.hibernate.SessionFactory到自定义的Dao中 .

  当自定义的Dao实现了org.springframework.orm.hibernate3.support.HibernateDaoSupport  时,若Dao是以注解的形式提供bean,则要以注解的形式注入SessionFactory,而HibernateDaoSupport 中相关的set方法都是final 的,即不能覆盖:
  1. public final void setSessionFactory(SessionFactory sessionFactory) {  
  2.         if (this.hibernateTemplate == null || sessionFactory != this.hibernateTemplate.getSessionFactory()) {  
  3.             this.hibernateTemplate = createHibernateTemplate(sessionFactory);  
  4.         }  
  5.     }  
  6.   
  7. public final void setHibernateTemplate(HibernateTemplate hibernateTemplate) {  
  8.         this.hibernateTemplate = hibernateTemplate;  
  9.     }  
public final void setSessionFactory(SessionFactory sessionFactory) { if (this.hibernateTemplate == null || sessionFactory != this.hibernateTemplate.getSessionFactory()) { this.hibernateTemplate = createHibernateTemplate(sessionFactory); } } public final void setHibernateTemplate(HibernateTemplate hibernateTemplate) { this.hibernateTemplate = hibernateTemplate; }

解决方法:
  1. @Transactional  
  2. @Repository("baseLocationDao")  
  3. public class BaseLocationDaoImpl extends HibernateDaoSupport implements LocationDao{  
  4.     private Logger logger = LoggerFactory.getLogger(BaseLocationDaoImpl.class);  
  5.       
  6.     @Resource  
  7.     public void setMySessionFactory(SessionFactory sessionFactory){  
  8.         super.setSessionFactory(sessionFactory);  
  9.     }  
  10. }  
@Transactional @Repository("baseLocationDao") public class BaseLocationDaoImpl extends HibernateDaoSupport implements LocationDao{ private Logger logger = LoggerFactory.getLogger(BaseLocationDaoImpl.class); @Resource public void setMySessionFactory(SessionFactory sessionFactory){ super.setSessionFactory(sessionFactory); } }


而SessionFactory的实现类也应该配置成注解形式的:

  1. <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">  
  2.     <property name="dataSource" ref="dataSource" />  
  3.     <property name="packagesToScan" value="com.pbn.oss.location"></property>  
  4.     <property name="schemaUpdate" value="true" />  
  5.     <property name="hibernateProperties">  
  6.         <props>  
  7.             <prop key="hibernate.format_sql">true</prop>  
  8.             <prop key="hibernate.show_sql">true</prop>  
  9.             <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop>  
  10.             <prop key="hibernate.query.factory_class">org.hibernate.hql.ast.ASTQueryTranslatorFactory</prop>  
  11.         </props>  
  12.     </property>  
  13. </bean>  

 

、、、、、、、、、、、、、、、、、、、、、、

类:

@Repository(value = "fragRecommendDao")
public class RecommendDaoImpl extends GenericDaoImpl<Recommend> implements RecommendDao {

xml配置:

 <bean id="fragRecommendDao" class="com.sohu.group.frag.dao.impl.RecommendDaoImpl">
  <property name="sessionFactory" ref="sessionFactoryOracle" />
 </bean>

 

  <!-- Hibernate SessionFactory -->
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="configLocation" value="classpath:hibernate.cfg.xml"/>
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
                hibernate.query.substitutions=true 'Y', false 'N'
                hibernate.cache.use_second_level_cache=true
                hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
                hibernate.hbm2ddl.auto=update
            </value>
            <!-- Turn batching off for better error messages under PostgreSQL -->
            <!-- hibernate.jdbc.batch_size=0 -->
        </property>
    </bean>
   
    <bean id="sessionFactoryOracle" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="dataSourceOracle"/>
        <property name="configLocation" value="classpath:hibernate.cfg.oracle.xml"/>
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=${hibernate.oracle.dialect}
                hibernate.query.substitutions=true 'Y', false 'N'
                hibernate.cache.use_second_level_cache=true
                hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider
            </value>
            <!-- Turn batching off for better error messages under PostgreSQL -->
            <!-- hibernate.jdbc.batch_size=0 -->
        </property>
    </bean>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值