Rumah > Java > javaTutorial > Bagaimana untuk Menyambungkan Repositori JPA Data Spring Berbilang kepada Sumber Data Berbeza dalam Boot Spring?

Bagaimana untuk Menyambungkan Repositori JPA Data Spring Berbilang kepada Sumber Data Berbeza dalam Boot Spring?

Mary-Kate Olsen
Lepaskan: 2024-10-24 21:35:31
asal
999 orang telah melayarinya

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

Spring Boot, Spring Data JPA dengan Multiple DataSources

Menyambungkan berbilang repositori ke sumber data yang berbeza boleh dilakukan menggunakan Spring Boot dan Spring Data JPA. Catatan blog yang dirujuk menyediakan penyelesaian, tetapi berikut ialah pendekatan yang lebih terperinci:

Konfigurasi:

Buat kelas konfigurasi berasingan untuk setiap sumber data. Di bawah ialah contoh untuk dua sumber data:

CustomerDbConfig (Sumber Data Pertama)

<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>
Salin selepas log masuk

OrderDbConfig (Sumber Data Kedua)

<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>
Salin selepas log masuk

Entiti:

Tentukan entiti (model) untuk setiap sumber data, seperti:

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

    // ...
}

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

    // ...
}</code>
Salin selepas log masuk

Repositori:

Buat repositori untuk setiap entiti, seperti:

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

public interface OrderRepository extends JpaRepository<Order, Integer> {}</code>
Salin selepas log masuk

Aplikasi (Kelas Utama):

Dalam kelas aplikasi utama, pastikan bahawa semua kacang yang diperlukan dicipta dan konteks aplikasi Spring disediakan.

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

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}</code>
Salin selepas log masuk

Sifat:

Konfigurasikan dua sumber data dalam fail application.properties, termasuk butiran seperti URL, nama pengguna, kata laluan dan nama kelas pemandu.

<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>
Salin selepas log masuk

Penyelesaian masalah:

Jika anda menghadapi pengecualian yang berkaitan dengan kacang yang hilang atau pendua, pastikan bahawa :

  • Takrifan kacang dalam kelas konfigurasi adalah unik.
  • Pakej asas untuk setiap repositori adalah betul.
  • Sifat sumber data dikonfigurasikan dengan betul dalam aplikasi .properties.
  • Setiap anotasi @Transactional menentukan pengurus transaksi yang betul untuk sumber data masing-masing.

Atas ialah kandungan terperinci Bagaimana untuk Menyambungkan Repositori JPA Data Spring Berbilang kepada Sumber Data Berbeza dalam Boot Spring?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan