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 サイトの他の関連記事を参照してください。