Rumah  >  Artikel  >  Java  >  ## Mengapa Kriteria Hibernate Mengembalikan Pesanan Pendua dengan FetchType.EAGER?

## Mengapa Kriteria Hibernate Mengembalikan Pesanan Pendua dengan FetchType.EAGER?

Linda Hamilton
Linda Hamiltonasal
2024-10-26 04:18:02428semak imbas

## Why Does Hibernate Criteria Return Duplicate Orders with FetchType.EAGER?

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!

Kenyataan:
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