Maison > Java > javaDidacticiel > le corps du texte

Comment connecter plusieurs référentiels JPA Spring Data à différentes sources de données dans Spring Boot ?

Mary-Kate Olsen
Libérer: 2024-10-24 21:35:31
original
796 Les gens l'ont consulté

How to Connect Multiple Spring Data JPA Repositories to Different Data Sources in Spring Boot?

Spring Boot, Spring Data JPA avec plusieurs sources de données

La connexion de plusieurs référentiels à différentes sources de données est possible à l'aide de Spring Boot et Spring Data JPA. L'article de blog référencé fournit une solution, mais voici une approche plus détaillée :

Configuration :

Créez des classes de configuration distinctes pour chaque source de données. Vous trouverez ci-dessous des exemples pour deux sources de données :

CustomerDbConfig (première source de données)

<code class="java">@Configuration
@EnableJpaRepositories(
        entityManagerFactoryRef = "customerEntityManager",
        transactionManagerRef = "customerTransactionManager",
        basePackages = {"com.mm.repository.customer"})
public class CustomerDbConfig {

    // Bean definitions for data source, entity manager factory, and transaction manager for first data source
}</code>
Copier après la connexion

OrderDbConfig (deuxième source de données)

<code class="java">@Configuration
@EnableJpaRepositories(
        entityManagerFactoryRef = "orderEntityManager",
        transactionManagerRef = "orderTransactionManager",
        basePackages = {"com.mm.repository.order"})
public class OrderDbConfig {

    // Bean definitions for data source, entity manager factory, and transaction manager for second data source
}</code>
Copier après la connexion

Entités :

Définir des entités (modèles) pour chaque source de données, telles que :

<code class="java">@Entity
@Table(name = "customer")
public class Customer {

    // ...
}

@Entity
@Table(name = "order")
public class Order {

    // ...
}</code>
Copier après la connexion

Référentiels :

Créez des référentiels pour chaque entité, tels que :

<code class="java">public interface CustomerRepository extends JpaRepository<Customer, Integer> {}

public interface OrderRepository extends JpaRepository<Order, Integer> {}</code>
Copier après la connexion

Application (classe principale) :

Dans la classe d'application principale, assurez-vous que tous les beans nécessaires sont créés et le contexte de l'application Spring est configuré.

<code class="java">@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}</code>
Copier après la connexion

Propriétés :

Configurez les deux sources de données dans le fichier application.properties, y compris des détails tels que l'URL, le nom d'utilisateur, le mot de passe et le nom de la classe du pilote.

<code class="properties"># Customer Data Source
spring.datasource.primary.url=...
spring.datasource.primary.username=...
spring.datasource.primary.password=...
spring.datasource.primary.driverClassName=...

# Order Data Source
spring.datasource.secondary.url=...
spring.datasource.secondary.username=...
spring.datasource.secondary.password=...
spring.datasource.secondary.driverClassName=...</code>
Copier après la connexion

Dépannage :

Si vous rencontrez des exceptions liées à des beans manquants ou en double, assurez-vous que :

  • Les définitions de bean dans les classes de configuration sont uniques.
  • Les packages de base pour chaque référentiel sont corrects.
  • Les propriétés de la source de données sont configurées correctement dans l'application .properties.
  • Chaque annotation @Transactional spécifie le gestionnaire de transactions correct pour la source de données respective.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!