1. 程式人生 > >Spring4 + jpa 或者 Mybaits 或者JDBC 動態資料庫切換例項 (2)

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.

基本路徑如下.