[英]handling multiple database connections using session factories with Spring and Hibernate
[英]Using two transaction managers and session factories with spring & hibernate annotations
我在applicationContext中定义了两个事务管理器,它们引用了两个完全不同的sessionFactories。 我正在尝试对其中一个事务管理器使用批注,但是似乎正在将所有批注应用于两个事务管理器。
我要迁移到的新数据库具有<property name="hbm2ddl.auto">create</property>
,而我要迁移的另一个数据库具有<property name="hbm2ddl.auto">validate</property>
我已经用@Entity
注释了我的新域对象,hibernate试图在旧数据库上验证这些类,我以为我已经设置为忽略注释(通过不指定注释)。 以下是appContext的相关片段:
<tx:annotation-driven transaction-manager="transactionManager1" />
<context:property-placeholder location="file:${catalina.home}/conf/database.properties" ignore-unresolvable="true"/>
<bean id="sessionFactory1" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean" p:dataSource-ref="dataSource1" p:configLocation="WEB-INF/classes/hibernate.cfg.xml" p:packagesToScan="com.mycompany"/>
<!-- Declare a datasource that has pooling capabilities-->
<bean id="dataSource1" class="com.mchange.v2.c3p0.ComboPooledDataSource"
p:driverClass="${app.driverClassName}" p:jdbcUrl="${app.url}"
p:user="${app.username}" p:password="${app.password}"
<!-- Declare a transaction manager-->
<bean id="transactionManager1" class="org.springframework.orm.hibernate3.HibernateTransactionManager" p:sessionFactory-ref="sessionFactory1" />
和旧数据库在同一appContext中:
<bean id="sessionFactory2" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean" p:dataSource-ref="dataSource2" p:configLocation="WEB-INF/classes/hibernateTraveller.cfg.xml" p:packagesToScan="com.mycompany"/>
<!-- Declare a datasource that has pooling capabilities-->
<bean id="dataSource2" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"
p:driverClass="${app2.driverClassName}" p:jdbcUrl="${app2.url}"
p:user="${app2.username}" p:password="${app2.password}"
<!-- Declare a transaction manager-->
<bean id="transactionManager2" class="org.springframework.orm.hibernate3.HibernateTransactionManager"
p:sessionFactory-ref="sessionFactoryTraveller">
<qualifier value="legacyDB"/>
</bean>
有指针吗?
对于不使用注释的旧数据库,应使用LocalSessionFactoryBean而不是AnnotationSessionFactoryBean 。 AnnotationSessionFactoryBean的全部目的是使用注释。 如果您不想使用注释,则可以使用LocalSessionFactoryBean。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.