Hibernate+Spring多数据库解决方案(二)
上篇 Hibernate+Spring多数据库解决方案(一)
4) 事务控制,使用Spring的 JtaTransactionManager 类来控制,但要为其注入JBboss启动后的 JTA事务管理器的名字 java:comp/UserTransaction; 使用Spring的自动代理功能为 业务类 *Service 进行拦截,控制事务边界。
<bean id="transactionManager" value="java:comp/UserTransaction"/> </bean> <bean id="transactionAdvisor" > <ref local="transactionManager"/> </property> <property name="transactionAttributes"> <props> <prop key="*">PROPAGATION_REQUIRED</prop> </props> </property> </bean> <!-- 注册自动代理创建,为业务Bean添加事务拦截器 --> <bean id="BOAutoProxyCreator" value="true"></property> <property name="beanNames"> <list> <value>*Service</value> </list> </property> <property name="interceptorNames"> <list> <value>trasactionMethodPointcutAdvisor</value> <!-- 注意: 事务拦截器必须包含在业务日志拦截器中,以免事务控制混乱;或者将业务日志的方法recordLog 设置为 PROPAGATION_REQUIRES_NEW 属性 --> </list> </property> </bean> <
<xa-datasource> <jndi-name>XAOracleDS_MAIN</jndi-name> <track-connection-by-tx/> <isSameRM-override-value>false</isSameRM-override-value> <use-java-context>false</use-java-context> <xa-datasource-class>oracle.jdbc.xa.client.OracleXADataSource</xa-datasource-class> <xa-datasource-property name="URL">jdbc:oracle:thin:@192.168.0.25:1521:DB_SYS</xa-datasource-property> <xa-datasource-property name="User">admin</xa-datasource-property> <xa-datasource-property name="Password">admin</xa-datasource-property> <!-- Uses the pingDatabase method to check a connection is still valid before handing it out from the pool --> <!--valid-connection-checker-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleValidConnectionChecker</valid-connection-checker-class-name--> <!-- Checks the Oracle error codes and messages for fatal errors --> <exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</exception-sorter-class-name> <!-- Oracles XA datasource cannot reuse a connection outside a transaction once enlisted in a global transaction and vice-versa --> <no-tx-separate-pools/> <metadata> <type-mapping>Oracle9i</type-mapping> </metadata> </xa-datasource>
public class DAOFactory { /** * 创建DAO类 * @param daoClass * @return * @throws Exception */ public static BaseDAO createDAO(Class daoClass) throws Exception { SessionFactoryManager sessionFactoryManager = (SessionFactoryManager) BeanFactory.getBean(SessionFactoryManager.class); BaseDAO dao = null; try { dao = (BaseDAO) BeanFactory.createBean(daoClass); } catch (Exception e) { throw e; } SessionFactory sf = sessionFactoryManager.getSessionFactory( dao.getVoClass() ); dao.setSessionFactory(sf); //注入sessionFactory return dao; } }