ホームページ >Java >&#&チュートリアル >Spring Boot と Spring Data JPA を使用して複数のデータ ソースに接続するにはどうすればよいですか?
Spring Boot と Spring Data JPA を使用して、複数のデータ ソースに接続できます。これを行うには、 @EnableJpaRepositories アノテーションを使用してリポジトリの基本パッケージを指定し、 @EnableTransactionManagement アノテーションを使用してトランザクション管理を有効にします。その後、リポジトリ メソッドで @Transactional アノテーションを使用して、各メソッドで使用するデータ ソースを指定できます。
たとえば、次のコードは、2 つのデータ ソースに接続するように Spring Boot を構成する方法を示しています。
<code class="java">@Configuration @EnableJpaRepositories( entityManagerFactoryRef = "orderEntityManager", transactionManagerRef = "orderTransactionManager", basePackages = {"com.mm.repository.customer"}) public class CustomerDbConfig { @Bean(name = "customerEntityManager") public LocalContainerEntityManagerFactoryBean entityManagerFactory(){ // ... } // ... } @Configuration @EnableJpaRepositories( entityManagerFactoryRef = "orderEntityManager", transactionManagerRef = "orderTransactionManager", basePackages = {"com.mm.repository.order"}) public class OrderDbConfig { @Bean(name = "orderEntityManager") public LocalContainerEntityManagerFactoryBean entityManagerFactory(){ // ... } // ... }</code>
このコードは、各データ ソースに 1 つずつ、2 つの EntityManagerFactory Bean を作成します。リポジトリ メソッドの @Transactional アノテーションは、各メソッドに使用する EntityManagerFactory を指定します。たとえば、次のコードは @Transactional アノテーションを使用して、findCustomer メソッドが customerEntityManager Bean を使用するように指定する方法を示しています。
<code class="java">@Repository public interface CustomerRepository { @Transactional(value = "customerEntityManager") Customer findCustomer(Integer id); // ... }</code>
複数のデータ ソースに接続する場合は、次の点を確認することが重要です:
以上がSpring Boot と Spring Data JPA を使用して複数のデータ ソースに接続するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。