Spring4 + jpa 或者 Mybaits 或者JDBC 动态数据库切换实例 (2)

继续 .  

    在上一篇文章中多数据源切换的实现,  下面是jpa的   配置代码

                <!--允许使用注解方式配置事务 -->  
<tx:annotation-driven transaction-manager="transactionManager" mode="proxy" />


        <!--service端使用inject方式查询扫描 --> 
<jpa:repositories  
entity-manager-factory-ref="entityManagerFactory"
transaction-manager-ref="transactionManager"
base-package="cn.com.taiji.repository" />

<!-- JPA 事务管理 --> 
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
<property name="dataSource" ref="dataSource" /> 
<property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

<!-- JPA 实体管理工厂 --> 
<bean id="entityManagerFactory"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="persistenceXmlLocation" value="classpath:META-INF/persistence-oracle.xml" />
<!-- <property name="persistenceUnitName" value="db1"></property> --><!-- 实体配置方式3  -->
<property name="packagesToScan">
   <list>
    <value>cn.com.taiji.domain</value>
   </list>
</property>
<property name="jpaVendorAdapter">
   <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter" />
</property>

</bean>

            

一. <jpa:repositories > 标签中指向了  持久层的包路径

二. entityManagerFactory 中配置了多数据源对  实体类自动扫描的配置.

            packagesToScan 指向实体@Entity 文件路径

            persistenceXmlLocation  指向数据库了配置.代码如下. 原先的写法是在persistence-oracle.xml中再配置一个

                                                       orm-oracle.xml指向实体文件.


<?xml version="1.0" encoding="UTF-8"?>

<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"
version="2.1">


<persistence-unit name="db1" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<!-- <mapping-file>META-INF/orm-oracle.xml</mapping-file> --><!-- 实体配置方式1  -->
<!-- <class>cn.com.taiji.domain.Code</class> --><!-- 实体配置方式2  -->
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.Oracle10gDialect" />
<property name="hibernate.max_fetch_depth" value="3" />
<property name="hibernate.hbm2ddl.auto" value="no" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.format_sql" value="false" />
</properties>
</persistence-unit>

</persistence>


    写到这里发现,   这里种配置又不能满足 多种数据库的配置了.     无奈.   多种数据库的操作貌似还是要按照我去年写的文章来配置多个sessionFactory来弄.     好歹现在数据库一般项目比较统一.  要么oracle  要么  mysql.


基本路径如下.


    



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值