"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Pourquoi les critères Hibernate Critères renvoient-ils les commandes en double?

Pourquoi les critères Hibernate Critères renvoient-ils les commandes en double?

Publié le 2025-04-14
Parcourir:423

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

Hibernate Critères Renvoie les ordres en double avec fetchtype.eager

question:

Lors de la définition de la question de l'ordre de l'ordre de Fetch pour que les moments de l'ordre se répertorient pour faire la liste pour les motifs de l'ordre de l'ordre pour faire de l'ordre pour que l'ordre de faire de l'ordre se répertorie sur l'ordre de l'ordre de l'ordre pour FetchType. Dans la liste résultante récupérée à l'aide des critères?

Réponse:

Ce comportement est attendu. Avec FetchType.Aeager, une jointure est effectuée pour récupérer avec impatience les OrderTransactions. Il en résulte le même nombre de résultats qu'une jointure SQL standard, où chaque commande sera présente dans l'ensemble de résultats pour chaque OrderTransaction OrderStransaction correspondante.

pour comprendre cela, considérez la déclaration SQL générée:

SELECT o.*, l.* from ORDER o LEFT OUTER JOIN LINE_ITEMS l ON o.ID = l.ORDER_ID

Solution pour obtenir des résultats distincts:

pour filtrer les résultats en double avec FetchType.eger, vous pouvez utiliser un type de collection qui maintient l'inscription, telle que un ordre de lien = nouveau LinkedHashSet (Session.CreateCriteria (Order.Class) .add (restrictions.in ("Orderstatus", OrderFilter.getStatuSesToShow ())) .liste() );

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3