Kriteria Hibernate Mengembalikan Pesanan Pendua dengan FetchType.EAGER
Soalan:
Apabila menetapkan ambil jenis senarai Urusniaga pesanan pesanan kepada FetchType.EAGER, mengapakah pesanan itu muncul beberapa kali dalam senarai yang terhasil yang diambil menggunakan Kriteria?
Jawapan:
Tingkah laku ini ialah dijangka. Dengan FetchType.EAGER, gabungan dilakukan untuk mengambil orderTransactions dengan penuh semangat. Ini menghasilkan bilangan hasil yang sama seperti gabungan SQL standard, di mana setiap pesanan akan hadir dalam set keputusan untuk setiap Urusniaga pesanan yang sepadan.
Untuk memahami perkara ini, pertimbangkan pernyataan SQL yang dijana:
SELECT o.*, l.* from ORDER o LEFT OUTER JOIN LINE_ITEMS l ON o.ID = l.ORDER_ID
Dalam penyata ini, untuk setiap pesanan, semua item baris yang berkaitan akan diambil, yang membawa kepada berbilang kejadian tertib yang sama dalam set hasil.
Penyelesaian untuk Mendapatkan Keputusan Yang Berbeza:
Untuk menapis hasil pendua dengan FetchType.EAGER, anda boleh menggunakan jenis Koleksi yang mengekalkan susunan sisipan, seperti LinkedHashSet:
Collection<Order> result = new LinkedHashSet( session.createCriteria(Order.class) .add(Restrictions.in("orderStatus", orderFilter.getStatusesToShow())) .list() );
Atas ialah kandungan terperinci ## Mengapa Kriteria Hibernate Mengembalikan Pesanan Pendua dengan FetchType.EAGER?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!