У меня есть требование для подключения разных типов баз данных для разных сред, т. Е. Для одной тестовой системы, для одной рабочей базы и для другой базы данных. Для этой я настроил разные источники данных.
Я использую данные пружины 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>