Rumah > Java > javaTutorial > JOIN lwn. JOIN FETCH dalam JPA dan Hibernate: Bilakah Saya Perlu Menggunakan Setiap?

JOIN lwn. JOIN FETCH dalam JPA dan Hibernate: Bilakah Saya Perlu Menggunakan Setiap?

Linda Hamilton
Lepaskan: 2024-11-11 08:54:02
asal
361 orang telah melayarinya

JOIN vs. JOIN FETCH in JPA and Hibernate: When Should I Use Each?

Sertai vs. Sertai Ambil dalam JPA dan Hibernate

Apabila bekerja dengan JPA dan Hibernate, dua jenis cantuman yang biasa digunakan ialah JOIN dan JOIN FETCH. Mari kita terokai perbezaan mereka dan bila sesuai untuk menggunakan setiap jenis.

Pertanyaan 1: SERTAI

FROM Employee emp
JOIN emp.department dep
Salin selepas log masuk

Pertanyaan ini mendapatkan semula semua entiti Pekerja yang mempunyai sekurang-kurangnya satu Jabatan yang berkaitan. Hasil pertanyaan ini akan mengandungi objek Pekerja dengan objek Jabatan mereka dimuatkan dengan malas. Ini bermakna Hibernate tidak akan mendapatkan semula objek Jabatan semasa pertanyaan awal tetapi apabila ia diakses buat kali pertama.

Pertanyaan 2: JOIN FETCH

FROM Employee emp
JOIN FETCH emp.department dep
Salin selepas log masuk

Tidak seperti JOIN, JOIN Pertanyaan FETCH tidak sabar-sabar memuatkan objek Jabatan yang dikaitkan dengan entiti Pekerja. Ini menyebabkan objek Jabatan diambil semula semasa pertanyaan awal dan bukannya dimuatkan dengan malas kemudian.

Memilih Jenis yang Tepat

Pilihan antara JOIN dan JOIN FETCH bergantung pada keperluan aplikasi khusus anda:

  • Jika anda yakin bahawa anda memerlukan objek Jabatan untuk setiap Pekerja yang diambil, SERTAI FETCH ialah pilihan yang lebih cekap kerana ia menghapuskan keperluan untuk pertanyaan berikutnya untuk mengambil objek Jabatan.
  • Jika anda tidak pasti sama ada anda memerlukan objek Jabatan untuk semua entiti Pekerja, secara amnya lebih baik menggunakan JOIN untuk mengelakkan overhed yang tidak perlu.

Tambahan Pertimbangan

  • Jika pemetaan @OneToMany antara Pekerja dan Jabatan dikonfigurasikan dengan FetchType.EAGER, menggunakan JOIN masih akan menyebabkan objek Jabatan dimuatkan dengan penuh semangat.
  • JOIN FETCH boleh berguna apabila digabungkan dengan syarat WHERE pada entiti yang digabungkan, kerana ia membolehkan pertanyaan yang lebih cekap daripada berbilang SERTAI.

Atas ialah kandungan terperinci JOIN lwn. JOIN FETCH dalam JPA dan Hibernate: Bilakah Saya Perlu Menggunakan Setiap?. 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