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

相关文章

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

gitlab安装及邮箱配置和常用使用方式

《gitlab安装及邮箱配置和常用使用方式》:本文主要介绍gitlab安装及邮箱配置和常用使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装GitLab2.配置GitLab邮件服务3.GitLab的账号注册邮箱验证及其分组4.gitlab分支和标签的

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热