JPA と Hibernate で計算されたプロパティを処理する方法
Java Persistence の領域では、Bean はデータベースから値を派生するプロパティを所有することがよくあります。データベース列に直接マッピングするのではなく、計算を行います。これは、通常、列とプロパティの単純な関係を前提とする JPA や Hibernate などのフレームワークにとって課題となります。
この難題に対する 1 つの有効な解決策は、Hibernate が提供する @Formula アノテーションにあります。このアノテーションを使用すると、プロパティの値をオンザフライで計算する SQL フラグメントを指定できます。
計算されたプロパティに @Formula を使用する
プロパティに @Formula のアノテーションを付けることで、指定された SQL フラグメントを使用して値を取得するように Hibernate に指示します。たとえば、次の Bean について考えてみましょう:
@Entity public class Book { @Id private Long id; private String title; @Formula(value = "COUNT(c) where c.book_id = id") private Integer pageCount; }
ここでは、pageCount プロパティはどのデータベース列にもマップされていません。代わりに、Hibernate が Book をフェッチすると、提供された SQL フラグメント (この場合は COUNT()) を実行してページ数を決定します。
@Formula の詳細
基本的な数式の注釈を超えて、次のことができます。また:
追加リソース
さらに詳しい洞察と使用例については、次を参照してください:
以上がJPA と Hibernate の @Formula アノテーションを使用して計算プロパティを効率的に管理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。