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

相关文章

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT