Hibernate Criteria 使用 FetchType.EAGER 返回多个重复订单
问题:
使用时具有 FetchType.EAGER 的 Hibernate Criteria 用于一对多关系,结果列表包含同一 Order 对象的多个副本。
原始代码:
<code class="java">public List<OrderTransaction> getOrderTransactions() { return orderTransactions; }</code>
使用 FetchType.EAGER 修改代码:
<code class="java">public List<OrderTransaction> getOrderTransactions() { return orderTransactions; }</code>
问题:
为什么使用 FetchType.EAGER 修改代码会导致多个Order 对象的副本?
答案:
启用急切获取时会出现此行为。在 Order 和 OrderTransaction 表之间执行联接,产生与常规 SQL 联接相同的行数。因此,每个 Order 对象出现多次,对应于相关 OrderTransaction 记录的数量。
说明:
使用 FetchType.EAGER 获取数据时使用了外连接。这意味着即使一个Order没有相关的OrderTransaction记录,它仍然会包含在结果集中。结果是 Order 对象的列表,每个对象都可能与多个 OrderTransaction 对象关联。
解决方案:
要避免 Order 对象的多个副本,请考虑使用集合而不是列表以防止重复。或者,在 Criteria 查询中使用 DistinctRootEntity,它显式指定要返回的不同 Order 对象。
示例:
<code class="java">Criteria criteria = getHibernateSession() .createCriteria(Order.class) .setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY) .add(Restrictions.in("orderStatus", orderFilter.getStatusesToShow()));</code>
以上是## 为什么使用 FetchType.EAGER 的 Hibernate Criteria 会导致重复的订单对象?的详细内容。更多信息请关注PHP中文网其他相关文章!