Menggunakan Klausa JPQL IN dengan Bekas Java untuk Penetapan Nilai Dinamik
Klausa JPQL IN membolehkan anda membandingkan harta entiti dengan senarai nilai yang ditentukan. Walau bagaimanapun, ia menimbulkan cabaran apabila nilai ini tidak diketahui terlebih dahulu atau sering berubah.
Pertimbangan Pertanyaan
Pendekatan tradisional untuk menyenaraikan secara eksplisit setiap parameter dalam klausa IN menjadi membosankan dan tidak praktikal apabila berurusan dengan set nilai yang besar atau dinamik. Timbul persoalan: adakah terdapat cara untuk menentukan bekas (tatasusunan, senarai, set) yang secara automatik membuka gulungan nilainya untuk klausa IN?
Penyelesaian untuk JPA 2.0 dan Lebih Tinggi
JPA 2.0 memperkenalkan keupayaan untuk menghantar Koleksi sebagai parameter kepada klausa IN. Sintaksnya adalah seperti berikut:
Query q = em.createQuery("select item from Item item where item.name IN :names", Item.class); List<String> names = Arrays.asList("foo", "bar"); q.setParameter("names", names);
Ini membolehkan anda menetapkan nilai secara dinamik kepada klausa IN berdasarkan kandungan Koleksi.
Penghadan untuk Hibernate 3.5.1
Walaupun JPA 2.0 membenarkan parameterkan klausa IN dengan Koleksi, Hibernate 3.5.1 mempunyai pepijat yang memerlukan tanda kurungan tambahan di sekeliling parameter:
Query q = em.createQuery("select item from Item item where item.name IN (:names)", Item.class);
Ketidakkonsistenan ini telah dilog sebagai HHH-5126 dan ditangani dalam versi Hibernate yang kemudian.
Kesimpulan
Dengan menggunakan ciri parameterisasi Koleksi dalam JPQL DALAM klausa, anda boleh memudahkan pertanyaan yang melibatkan set nilai dinamik atau besar. Ini bukan sahaja mengurangkan kerumitan pertanyaan tetapi juga meningkatkan fleksibiliti dan kecekapan kod anda apabila bekerja dengan set data berubah-ubah.
Atas ialah kandungan terperinci Bolehkah saya Menggunakan Bekas Java dengan Klausa IN JPQL untuk Pertanyaan Dinamik?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!