Spring および Hibernate で @Lob フィールドの遅延読み込みが失敗するのはなぜですか?

Susan Sarandon
リリース: 2024-11-02 18:28:02
オリジナル
414 人が閲覧しました

Why Does Lazy Loading Fail for @Lob Fields in Spring and Hibernate?

Spring および Hibernate での @Lob の遅延読み込みの問題

Spring および Hibernate を利用する Web アプリケーションでは、ファイル関連データを含むデータベース レコードがWeb ページ上にレンダリングされます。データ量が控えめな場合、プロセスはスムーズに動作しますが、データ量が多すぎると「OutOfMemoryError」がトリガーされます。

最初のトラブルシューティング手順として、「blobField」プロパティを「null」に設定するとメモリの問題が解決されました。 @Basic(fetch=FetchType.LAZY) アノテーションにもかかわらず、ロードは無効でした。

説明と回避策

Hibernate のドキュメントによると、@Lob フィールドは本質的に遅延型であり、明示的な Lazy アノテーションを必要としません。ただし、データベースとドライバー間で一貫性のない動作が報告されています。

解決策の 1 つは、Javassist や Cglib などのバイトコード インストルメンテーション技術を使用します。

推奨される解決策

この問題に確実に対処するには、データ マッピングを再構築することをお勧めします。プロパティを利用する代わりに、「偽の」1 対 1 マッピングを作成します。プライマリ クラスから LOB フィールドを削除し、同じテーブルとプライマリ キーを参照する、必要な LOB フィールドのみを含む新しいクラスを確立します。これらのマッピングを 1 対 1、フェッチ選択、および遅延 true としてマークします。このアプローチにより、親オブジェクトがセッションに残っている間、遅延読み込みが確実に行われます。

以上がSpring および Hibernate で @Lob フィールドの遅延読み込みが失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート