Как настроить несколько источников данных весной mvc, используя файл xml для данных весны jpa - PullRequest
0 голосов
/ 06 февраля 2020

У меня есть требование для подключения разных типов баз данных для разных сред, т. Е. Для одной тестовой системы, для одной рабочей базы и для другой базы данных. Для этой я настроил разные источники данных.

Я использую данные пружины JPA, так как эти источники данных будут выбирать по данным пружины JPA. Более того, если я изменю одно свойство из файла свойств, ему нужно выбрать источник данных.

        <context:property-placeholder location="classpath:application.properties"></context:property-placeholder>

    <context:component-scan base-package="basePackage" />

    <!-- Scans for repositories that will be auto-registered -->
    <jpa:repositories base-package="basePackage" />

<bean id="localMySQLDev"
      class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.mysql.jdbc.Driver" />
    <property name="url" value="jdbc:mysql://localhost:3306/localMysql?useSSL=false" />
    <property name="username" value="root" />
    <property name="password" value="root" />
</bean>



<bean id="localHanaDev"
      class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="com.sap.db.jdbc.Driver" />
    <property name="url"
              value="jdbc:sap://localhost:30015/hanaDev?autocommit=false" />
    <property name="username" value="" />
    <property name="password" value="" />
</bean>




    <bean id="entityManagerFactoryMySQL" 
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
        p:packagesToScan="com.itelligence.rampit" p:dataSource-ref="localMySQLDev">
        <property name="persistenceUnitName" value="mySQLPersistenceUnit" />
        <property name="jpaProperties">
            <props>
            <!--    <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> -->
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
                <!-- <prop key="hibernate.hbm2ddl.auto">create</prop> -->
                <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect</prop>
            </props>
        </property>
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">


            </bean>

        </property>
    </bean>

    <bean id="entityManagerFactoryHANA"
        class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"
        p:packagesToScan="com.itelligence.rampit" p:dataSource-ref="localHanaDev">
        <property name="persistenceUnitName" value="hanaPersistenceUnit" />
        <property name="jpaProperties">
            <props>
            <!--    <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> -->
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
                <!-- <prop key="hibernate.hbm2ddl.auto">create</prop> -->
                <prop key="hibernate.dialect">org.hibernate.dialect.HANAColumnStoreDialect</prop>
            </props>
        </property>
        <property name="jpaVendorAdapter">
            <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">


            </bean>

        </property>
    </bean>

    <!-- Transactions -->
    <tx:annotation-driven transaction-manager="transactionManagerMySQL" />

    <tx:annotation-driven transaction-manager="txnManagerAccountingHANA"/>


    <bean id="transactionManagerMySQL" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactoryMySQL" />
    </bean>

    <bean id="transactionManagerHANA" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="txnManagerAccountingHANA" />
    </bean>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...