アプリケーションのフィールドやsetterメソッドにEntityManagerをインジェクトする場合,さらに次の2種類の方法があります。
ただし,アプリケーションサーバではEJB3.0のejb-jar.xmlを使用したJPAの定義はできません。このため,EJBでJPAを使用する場合は,1.の方法で定義してください。
それぞれの方法について説明します。
@PersistenceContextを使用してEntityManagerをインジェクトする場合,インジェクト先のフィールドやsetterメソッドに@PersistenceContextを付加します。@PersistenceContextに指定できる属性について,次に示します。
unitName属性には,persistence.xmlで定義された永続化ユニットの名前を指定します。ただし,EJB-JARやWAR,EAR内に一つだけ永続化ユニットが定義されている場合など,使用する永続化ユニットが一意に特定できる場合には,unitName属性を省略することができます。unitName属性を省略した場合に,どの永続化ユニットが使用されるかについては,「5.11.2 永続化ユニット名の参照スコープ」を参照してください。
type属性には,永続化コンテキストのライフサイクルの種類を指定します。指定できる種類は,PersistenceContextType.TRANSACTIONまたはPersistenceContextType.EXTENDEDです。
type属性を省略した場合のデフォルトは,PersistenceContextType.TRANSACTIONです。
properties属性には,永続化ユニットを設定するためのJPAプロバイダ用のプロパティを指定できます。ここに指定したプロパティは,JPAプロバイダからEntityManagerを取得するときに,JPAプロバイダに渡されます。
インジェクションを使用する場合,通常name属性を指定する必要はありませんが,指定した場合には,name属性に指定した名前でEntityManagerがJNDI名前空間(java:comp/env)に登録されます。@PersistenceContextを使用してEntityManagerをインジェクトする例を次に示します。
@Stateless |
DDを使用してEntityManagerをインジェクトする場合,DDの<persistence-context-ref>タグに次に示すタグを定義します。
<description>タグには,定義するEntityManagerリファレンスの説明をユーザが自由に記述できます。このタグを指定した場合でも,指定した内容がアプリケーションの動作に影響を与えることはありません。また,このタグは省略できます。
<persistence-context-ref-name>タグには,EntityManagerがJNDI名前空間に登録されるときの名前を指定します。指定する名前は,java:comp/envからの相対パスです。EntityManagerのJNDI登録名は必須ではありませんが,JPA仕様では,java:comp/env/persistence以下にすることが推奨されています。
<persistence-unit-name>タグには,persistence.xmlに定義された永続化ユニットの名前を指定します。EJB-JARやWAR,EAR内に一つだけ永続化ユニットが定義されている場合など,使用する永続化ユニットを一意に特定できる場合には,<persistence-unit-name>タグは省略できます。<persistence-unit-name>タグを省略した場合に,どの永続化ユニットが使用されるかについては,「5.11.2 永続化ユニット名の参照スコープ」を参照してください。
<persistence-context-type>タグには,永続化コンテキストのライフサイクルの種類を指定します。「Transaction」または「Extended」を指定します。
<persistence-context-type>タグを省略した場合のデフォルトは,「Transaction」になります。
<persistence-property>タグには,永続化ユニットを設定するためのJPAプロバイダ用のプロパティを指定できます。ここに指定したプロパティは,JPAプロバイダからEntityManagerのファクトリを取得するときに,JPAプロバイダに渡されます。このタグは省略できます。
<injection-target>タグの<injection-target-class>タグにはインジェクト先のクラスを指定します。<injection-target>タグの<injection-target-name>タグには,インジェクト先のフィールド名またはsetterメソッド名を指定します。web.xmlに<persistence-context-ref>タグを定義してEntityManagerをインジェクトする例を次に示します。
... |