## FetchType.EAGER を使用した Hibernate 条件により注文オブジェクトが重複するのはなぜですか?

Mary-Kate Olsen
リリース: 2024-10-26 03:50:28
オリジナル
489 人が閲覧しました

## Why Does Hibernate Criteria with FetchType.EAGER Result in Duplicate Order Objects?

Hibernate 条件が FetchType.EAGER で複数の繰り返し注文を返す

問題:

を使用する場合1 対多の関係の 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 でデータをフェッチするときに外部結合が使用されます。 。これは、注文に関連する 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 条件により注文オブジェクトが重複するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!