Rumah > Java > javaTutorial > teks badan

Bagaimanakah atribut `mappedBy` dalam JPA dan Hibernate membantu mengurus perhubungan dua hala?

DDD
Lepaskan: 2024-11-03 06:34:30
asal
888 orang telah melayarinya

How does the `mappedBy` attribute in JPA and Hibernate help manage bidirectional relationships?

Memahami mappedBy dalam JPA dan Hibernate

Pengenalan

Perhubungan dua hala dalam pemetaan objek selalunya memerlukan pengendalian yang teliti untuk mengelakkan ketidakkonsistenan pangkalan data. Hibernate menawarkan sintaks ringkas, mappedBy, untuk mewujudkan perhubungan ini. Artikel ini menerangkan tujuan dan penggunaan mappedBy dalam JPA dan Hibernate.

Apakah itu mappedBy?

MappedBy menentukan bahawa kunci utama entiti pemilik disimpan dalam lajur dalam jadual pemilikan. Ia membolehkan anda memetakan hubungan dua hala di mana hanya satu jadual mempunyai kunci asing kepada yang lain. Ini memastikan entiti pemilik memegang pemilikan perhubungan dan mengelakkan perhubungan kitaran.

Tujuan mappedBy

MappedBy menyelesaikan isu mengelakkan kekangan kunci asing pendua dalam a hubungan dua hala. Dengan menetapkan satu jadual sebagai pemilik dan menyimpan kunci utamanya dalam jadual lain, ia memastikan integriti data yang konsisten.

Penggunaan

Untuk menggunakan mappedBy, anda perlu membuat anotasi @JoinColumn atau @JoinTable dalam entiti anak dengan atribut mappedBy. Atribut ini mengambil nama harta dalam entiti pemilik yang mewakili perhubungan.

Contoh

Pertimbangkan contoh yang disediakan dalam pertanyaan:

<code class="java">@OneToMany(fetch=FetchType.LAZY, cascade = {CascadeType.ALL})
@JoinColumn(name="IDAIRLINE")
public Set<AirlineFlight> getAirlineFlights() {
    return airlineFlights;
}</code>
Salin selepas log masuk

Anotasi @JoinColumn memberikan kekangan kunci asing kepada lajur IDAIRLINE dalam jadual AirlineFlight. Walau bagaimanapun, atribut mappedBy tiada.

Untuk menjadikan Syarikat Penerbangan pemilik perhubungan, kami boleh mengubah suai anotasi seperti berikut:

<code class="java">@OneToMany(fetch=FetchType.LAZY, cascade = {CascadeType.ALL})
@JoinColumn(name="IDAIRLINE", mappedBy="airline")
public Set<AirlineFlight> getAirlineFlights() {
    return airlineFlights;
}</code>
Salin selepas log masuk

Dengan menambahkan mappedBy="airline", kami menunjukkan bahawa lajur IDAIRLINE dalam jadual AirlineFlight ialah kunci utama entiti Syarikat Penerbangan. Ini mewujudkan hubungan dua hala di mana Syarikat Penerbangan memiliki contoh AirlineFlight tanpa memerlukan kunci asing pendua dalam jadual Syarikat Penerbangan.

Atas ialah kandungan terperinci Bagaimanakah atribut `mappedBy` dalam JPA dan Hibernate membantu mengurus perhubungan dua hala?. 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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan