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

相关文章

IDEA中配置Tomcat全过程

《IDEA中配置Tomcat全过程》文章介绍了在IDEA中配置Tomcat的六步流程,包括添加服务器、配置部署选项、设置应用服务器及启动,并提及Maven依赖可能因约定大于配置导致问题,需检查依赖版本... 目录第一步第二步第三步第四步第五步第六步总结第一步选择这个方框第二步选择+号,找到Tomca

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick