上篇
Hibernate+Spring多数据库解决方案(一)
4) 事务控制,使用Spring的 JtaTransactionManager 类来控制,但要为其注入JBboss启动后的 JTA事务管理器的名字 java:comp/UserTransaction; 使用Spring的自动代理功能为 业务类 *Service 进行拦截,控制事务边界。
<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="userTransactionName" value="java:comp/UserTransaction"/>
</bean>
<bean id="transactionAdvisor" class="org.springframework.transaction.interceptor.TransactionInterceptor">
<property name="transactionManager" >
<ref local="transactionManager"/>
</property>
<property name="transactionAttributes">
<props>
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>
<!-- 注册自动代理创建,为业务Bean添加事务拦截器 -->
<bean id="BOAutoProxyCreator" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">
<property name="proxyTargetClass" 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>
<
5) 配置 XA 数据源,在 jboss 4 的 server/default/deploy 目录下添加 oracle-xa-ds.xml 文件,在其中配置数据源,
<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>
这里是 XAOracleDS_MAIN 的配置,XAOracleDS_ORDER 的配置修改下 IP,user,password就可以了。
6) 关键代码
最关键的一步,就是以往 dao.setSessionFactory( sessionFactory ) 注入,要改为由 SessionFactoryManager 来注入,否则dao无法关联到正确的库,也无法操作数据。
我们项目中采用动态 Service,DAO 创建,也就是零配置,是在 DAOFactory 中进行的注入,在 DAOFactory.createDAO(daoClass)方法中,源代码贴出来,帮助理解:
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;
}
}
OK。 写个测试用例跑跑看:在删除user的时候,同时删除它对应的所有订单。
下篇再详细说下多库的集中模式,和 SessionFactoryManager 的实现原理。
分享到:
相关推荐
HibernateSpring多数据库解决方案.doc
基于Struts、Hibernate、Spring和Oracle技术的车辆管理系统,以其稳定可靠、高效灵活的特性,为各类企事业单位提供了强大的车辆管理解决方案。 Struts作为MVC框架的代表,为车辆管理系统提供了清晰的业务逻辑与页面...
【源码】基于JSP的车辆管理系统(Struts+Hibernate+Spring+Oracle)是一个功能强大且技术先进的车辆管理解决方案源码包。该源码包融合了多种主流技术,包括JSP、Struts、Hibernate、Spring和Oracle数据库,以提供...
"会员管理系统(struts+hibernate+spring)130226.rar" 是一个针对计算机专业的JSP源码资料包,它集成了Struts、Hibernate和Spring框架,旨在为用户提供一个高效、稳定且易于维护的会员管理解决方案。这个系统通过使用...
图书管理系统是一个基于Struts+Hibernate+Spring+Ext的计算机专业JSP源码资料包,它为开发者提供了一套完整的图书管理解决方案。这个系统采用了经典的MVC架构,将业务逻辑、数据访问和界面展示分离,使得代码结构...
该系统旨在提供一个简洁高效的图书管理解决方案,允许用户进行图书的增删改查操作,同时支持借阅和归还流程的管理。借助于Struts的Action类和Form Bean,用户界面与后端逻辑得以有效分离,使得功能扩展和维护更为...
整个系统实现了包括图书信息的增删改查、用户管理、借阅与归还等核心功能,是一个适合图书馆或学校进行图书管理的软件解决方案。该资料包不仅适合计算机专业的学生作为学习和实践的项目,也可供软件开发者参考和借鉴...
自1998年首次发布以来,MySQL以其卓越的性能、可靠性和可扩展性,成为全球范围内Web应用程序、企业级解决方案以及其他各种数据处理场景的首选数据库平台之一。 以下是对MySQL数据库的详细介绍: 核心特性与优势 ...
项目申报管理系统是一个为企业或教育机构设计的全面的项目管理解决方案,旨在简化项目申请、审批、监控和报告的过程。该系统利用了Java EE技术栈中的一些最强大的技术,包括Struts2用于MVC架构的Web层,Spring框架...
移动SSH项目(Struts + Spring + Hibernate + Oracle)是一个基于Java Web技术栈的企业级应用,旨在为企业提供一个高效、灵活且可扩展的解决方案。项目采用了Struts2作为表现层框架,Spring作为依赖注入和管理的核心...
Hibernate则是项目中的ORM(对象关系映射)解决方案,它将Java对象映射到Oracle数据库表中,极大地简化了数据访问层的代码编写,并提高了开发效率。Oracle数据库作为一个强大的关系型数据库管理系统,提供了高性能的...
在数据库方面,系统采用了MySQL5作为数据存储解决方案,确保了数据的稳定性与安全性。通过Hibernate框架的ORM映射机制,实现了对象与数据库之间的无缝对接,简化了数据操作过程。 此外,该系统源码还具备高度的可...
由于spring3.x,基于asm的某些特征,而这些asm还没有用jdk8编译,所以采用Spring 3+JDK8就会报错,提示错误信息( java.lang.IllegalArgumentException),具体解决方案有:1、Spring 3+JDK7及以下版本 2、Spring 4+JDK8...
2、支持多数据库:天乙社区6.0采用了Hibernate作为数据库持久化的解决方案,支持DB2、PostgreSQL、MySQL、Oracle、Sybase、Microsoft SQL Server、SAP DB、Informix、HypersonicSQL、Ingres、Progress、Mckoi SQL、...
这个资料包为开发者提供了一个全面的、易于使用的、高效的办公自动化解决方案,旨在帮助企业实现信息化建设,提高工作效率,降低运营成本。Struts1.2作为MVC框架,负责处理请求分发、控制跳转和视图渲染,使得系统...
整套技术来作为解决方案,实现模仿天猫网站的各种业务场景,现在开始使用框架技术,毕竟工作中还是要用框架。 本项目技术相对老旧,现在很少用 Struts2 了,但如果接手老项目的话还是要懂的,学习过程我们也可以认识...
1.1.2 解决方案 1 1.1.3 工作原理 3 1.2 配置Spring IoC容器中的Bean 4 1.2.1 问题 4 1.2.2 解决方案 4 1.2.3 工作原理 4 1.3 调用构造程序创建Bean 14 1.3.1 问题 14 1.3.2 解决方案 14 1.3.3 ...
1.1.2 解决方案 1 1.1.3 工作原理 3 1.2 配置Spring IoC容器中的Bean 4 1.2.1 问题 4 1.2.2 解决方案 4 1.2.3 工作原理 4 1.3 调用构造程序创建Bean 14 1.3.1 问题 14 1.3.2 解决方案 14 1.3.3 ...
该平台整合了Spring框架的依赖注入和面向切面编程的特性,SpringMVC框架的MVC模式以及Hibernate框架的对象关系映射和数据库操作功能,为用户提供了高效、稳定的招标解决方案。 这个网络招标平台为招标方和投标方...