Spring3+Hibernate3(Jpa) 配置多个数据源的解决方案(基于注解)

本文主要是介绍Spring3+Hibernate3(Jpa) 配置多个数据源的解决方案(基于注解),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

----------------配置文件--------------------------------

-------------------------------------META-INF/persistence.xml------------------------------------------------------

[html]  view plain copy print ?
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <persistence xmlns="http://java.sun.com/xml/ns/persistence"  
  3.              xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.              xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"  
  5.              version="1.0">  
  6.   
  7.     <!--配置mysql数据源-->  
  8.     <persistence-unit name="mysql" transaction-type="RESOURCE_LOCAL">  
  9.         <provider>org.hibernate.ejb.HibernatePersistence</provider>  
  10.         <non-jta-data-source>mysqlDataSource</non-jta-data-source>  
  11.        <!--这里的class是指要储存于本数据库的Entity-->  
  12.         <class>com.sunhope.model.core.ExternalEnvironment</class>     
  13.          
  14.         <properties>  
  15.             <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>  
  16.             <property name="hibernate.archive.autodetection" value="false"/>  
  17.             <property name="hibernate.transaction.auto_close_session" value="false"/>  
  18.             <property name="hibernate.hbm2ddl.auto" value="update" />  
  19.         </properties>  
  20.     </persistence-unit>  
  21.     <!--配置postgre数据源-->  
  22.     <persistence-unit name="postgre" transaction-type="RESOURCE_LOCAL">  
  23.         <provider>org.hibernate.ejb.HibernatePersistence</provider>  
  24.          
  25.         <non-jta-data-source>postgreDataSource</non-jta-data-source>  
  26.   
  27.         <class>com.sunhope.model.baseinfo.BdStorageCompany</class>  
  28.         <class>com.sunhope.model.baseinfo.BdHouseType</class>  
  29.         <class>com.sunhope.model.baseinfo.BdStorage</class>  
  30.         <class>com.sunhope.model.core.StoreEnvironment</class>  
  31.          
  32.         <properties>  
  33.             <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>  
  34.             <property name="hibernate.archive.autodetection" value="false"/>  
  35.             <property name="hibernate.transaction.auto_close_session" value="false"/>  
  36.             <property name="hibernate.hbm2ddl.auto" value="update" />  
  37.         </properties>  
  38.     </persistence-unit>  
  39.      
  40. </persistence>  

-------------------------------------applicationContext.xml---------------------------------------------------------

[html]  view plain copy print ?
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xmlns:tx="http://www.springframework.org/schema/tx"  
  5.     xsi:schemaLocation="http://www.springframework.org/schema/beans  
  6.             http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
  7.             http://www.springframework.org/schema/tx  
  8.             http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">  
  9.               
  10.     <bean id="defaultPersistenceUnitManager"  
  11.         class="org.springframework.orm.jpa.persistenceunit.DefaultPersistenceUnitManager">  
  12.         <property name="persistenceXmlLocation" value="classpath:META-INF/persistence.xml"/>  
  13.         <!--  comment dataSourceLooup to use jndi -->  
  14.         <property name="dataSourceLookup">  
  15.             <bean  
  16.                 class="org.springframework.jdbc.datasource.lookup.BeanFactoryDataSourceLookup" />  
  17.         </property>  
  18.     </bean>  
  19.       
  20.     <!-- #########################PostgreSql####################### -->     
  21.     <tx:annotation-driven transaction-manager="postgreEntityManagerFactory"/>  
  22.       
  23.     <bean id="postgreJpaVendor"  
  24.         class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">  
  25.          <property name="showSql" value="true" />  
  26.          <property name="generateDdl" value="true" />  
  27.     </bean>         
  28.       
  29.     <bean id="postgreDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  
  30.        <property name="driverClassName" value="org.postgresql.Driver"/>  
  31.        <property name="url" value="..."/>  
  32.        <property name="username" value="..."/>  
  33.        <property name="password" value="..."/>  
  34.         <property name="initialSize" value="1"/>  
  35.         <property name="maxActive" value="100"/>  
  36.         <property name="maxIdle" value="8"/>  
  37.         <property name="minIdle" value="1"/>  
  38.     </bean>  
  39.       
  40.     <bean id="postgreEntityManagerFactory"  
  41.         class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">  
  42.         <property name="persistenceUnitManager" ref="defaultPersistenceUnitManager" />  
  43.         <property name="persistenceUnitName" value="postgre" />  
  44.         <property name="jpaVendorAdapter" ref="postgreJpaVendor" />  
  45.         <property name="loadTimeWeaver">  
  46.             <bean  
  47.                 class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver" />  
  48.         </property>  
  49.         <property name="jpaDialect">  
  50.             <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect">  
  51.             </bean>  
  52.         </property>  
  53.     </bean>         
  54.           
  55.     <bean id="postgreTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">  
  56.         <property name="entityManagerFactory" ref="postgreEntityManagerFactory" />  
  57.         <qualifier value="postgreEM" />  
  58.         <property name="jpaDialect">  
  59.             <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />  
  60.         </property>  
  61.     </bean>  
  62.       
  63.     <!--########################MySql################################# -->      
  64.     <tx:annotation-driven transaction-manager="mysqlEntityManagerFactory"/>  
  65.       
  66.     <bean id="mysqlJpaVendor"  
  67.         class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">  
  68.          <property name="showSql" value="true" />  
  69.          <property name="generateDdl" value="true" />  
  70.     </bean>  
  71.       
  72.     <bean id="mysqlDataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  
  73.        <property name="driverClassName" value="org.gjt.mm.mysql.Driver"/>  
  74.        <property name="url" value="..."/>  
  75.        <property name="username" value="..."/>  
  76.        <property name="password" value="..."/>  
  77.         <property name="initialSize" value="1"/>  
  78.         <property name="maxActive" value="100"/>  
  79.         <property name="maxIdle" value="8"/>  
  80.         <property name="minIdle" value="1"/>  
  81.     </bean>  
  82.       
  83.     <bean id="mysqlEntityManagerFactory"  
  84.         class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">  
  85.         <property name="persistenceUnitManager" ref="defaultPersistenceUnitManager" />  
  86.         <property name="persistenceUnitName" value="mysql" />  
  87.         <property name="jpaVendorAdapter" ref="mysqlJpaVendor" />  
  88.         <property name="loadTimeWeaver">  
  89.             <bean  
  90.                 class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver" />  
  91.         </property>  
  92.         <property name="jpaDialect">  
  93.             <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect">  
  94.             </bean>  
  95.         </property>  
  96.     </bean>  
  97.       
  98.     <bean id="mysqlTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">  
  99.         <property name="entityManagerFactory" ref="mysqlEntityManagerFactory" />  
  100.         <qualifier value="mysqlEM" />  
  101.         <property name="jpaDialect">  
  102.             <bean class="org.springframework.orm.jpa.vendor.HibernateJpaDialect" />  
  103.         </property>  
  104.     </bean>  
  105.       
  106. </beans>  

---------------------注解

-------------------------------------DAO-------------------------------------------------------------

------------MySqlBaseDaoImpl.java

[java]  view plain copy print ?
  1. @Transactional(value="mysqlEM")  
  2. public class MySqlBaseDaoImpl<T> implements IMySqlBaseDao<T>{  
  3.     @PersistenceContext(unitName="mysql")  
  4.     protected EntityManager em;  
  5.       
  6.     //......  
  7. }  

------------PostgreSqlBaseDaoImpl.java

[java]  view plain copy print ?
  1. @Transactional(value="postgreEM")  
  2. public class PostgreSqlBaseDaoImpl<T> implements IPostgreSqlBaseDao<T>{  
  3.     @PersistenceContext(unitName="postgre")  
  4.     protected EntityManager em;  
  5.   
  6.     //.......  
  7. }  

-------------------------------------Service-------------------------------------------------------------

---------------ExternalEnvironmentServiceImpl.java

[java]  view plain copy print ?
  1. @Service  
  2. @Transactional(value="mysqlEM")  
  3. public class ExternalEnvironmentServiceImpl extends  
  4. MySqlBaseDaoImpl<ExternalEnvironment> implements IExternalEnvironmentService {  
  5.   
  6. }  

--------------------BdStorageCompanyServiceImpl.java

[java]  view plain copy print ?
  1. @Service  
  2. @Transactional(value="postgreEM")  
  3. public class BdStorageCompanyServiceImpl extends PostgreSqlBaseDaoImpl<BdStorageCompany>  
  4.         implements IBdStorageCompanyService {  
  5.   
  6. }  

-------------------------------------Model(Entity)-------------------------------------------------------------

-------------ExternalEnvironment.java---------------------------------------------------

[java]  view plain copy print ?
  1. @Entity(name = "TBL_EXTERNALENVIRONMENT")  
  2. public class ExternalEnvironment extends BaseModel{  
  3.   
  4.     //......  
  5.   
  6. }  

-----------------BdStorageCompany.java-------------------------------------------------

[java]  view plain copy print ?
  1. @Entity(name = "TBL_BDSTORAGECOMPANY")  
  2. public class BdStorageCompany extends BaseModel {  
  3.      
  4.    //.......  
  5.   
  6. }  

这篇关于Spring3+Hibernate3(Jpa) 配置多个数据源的解决方案(基于注解)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1079762

相关文章

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

SpringBoot3.4配置校验新特性的用法详解

《SpringBoot3.4配置校验新特性的用法详解》SpringBoot3.4对配置校验支持进行了全面升级,这篇文章为大家详细介绍了一下它们的具体使用,文中的示例代码讲解详细,感兴趣的小伙伴可以参考... 目录基本用法示例定义配置类配置 application.yml注入使用嵌套对象与集合元素深度校验开发

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环