このHow to auto-register entities with JPA/Hibernate: Unknown entityで同様の問題に遭遇しました。
jboss を 7 として、hibernate 4 (jboss を 7 として使用)、spring 3.0.5 を使用しています。エンティティ クラスに で注釈を付け@Entity
ます。そしてorg.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean
、entityManager を生成するために使用します。以下はBeanの定義です。
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName" value="java:jboss/datasources/appsubmission" />
</bean>
<bean id="entityManagerFactory"
class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="persistenceUnitName" value="app_sub_jpa" />
<property name="jpaVendorAdapter">
<bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
<property name="showSql" value="false" />
</bean>
</property>
</bean>
以下はpersistence.xmlファイルです。
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="app_sub_jpa">
<description>Hibernate for JPA</description>
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<non-jta-data-source>java:jboss/datasources/myds</non-jta-data-source>
<properties>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect" />
</properties>
</persistence-unit>
</persistence>
そして、次のように DB にアクセスしようとするまで、すべてがうまくいきます。
entityManager.persist(myEntity);
「MyEntity」は不明なエンティティであるという例外がスローされます。
Spring 3..0.5 + hierbnate 3.6.6.final + jboss as 7 Database accessで、Matt から persistence.xml ファイルに要素を追加するように言われ、問題は解決しました。しかし、問題は、別のプロジェクトで、同様の構成 (同じ persistence.xml と同様の Bean 定義) を使用し、すべてがうまくいき、unknown entity
例外がスローされないことです。また、<class>
jboss/hibernate はクラスを@Entity
アノテーション付きでスキャンし、それを PU に追加するため、persistence.xml ファイルでは必要ありません。
TRACE レベルのログを有効にすると、2 つのプロジェクトで jboss as 7 が同じ 2 つの persistenceUnit を作成するように見えます。
PersistenceUnitMetadata(version=2.0) [
name: app_sub_jpa
jtaDataSource: null
nonJtaDataSource: java:jboss/datasources/myds
transactionType: JTA
provider: org.hibernate.ejb.HibernatePersistence
classes[
]
packages[
]
mappingFiles[
]
jarFiles[
]
validation-mode: AUTO
shared-cache-mode: UNSPECIFIED
properties[
hibernate.dialect: org.hibernate.dialect.MySQLDialect
]]
11:23:45,127 DEBUG [org.hibernate.ejb.Ejb3Configuration] (MSC service thread 1-3) Processing PersistenceUnitInfo [
name: app_sub_jpa
persistence provider classname: org.hibernate.ejb.HibernatePersistence
classloader: ModuleClassLoader for Module "deployment.admin.war:main" from Service Module Loader
Temporary classloader: org.jboss.as.jpa.classloader.TempClassLoader@28e13c84
excludeUnlistedClasses: false
JTA datasource: null
Non JTA datasource: org.jboss.jca.adapters.jdbc.WrapperDataSource@5b4c1313
Transaction type: JTA
PU root URL: vfs:/D:/Server/jboss-as-7.0.0.Final/bin/content/admin.war/WEB-INF/classes/
Shared Cache Mode: UNSPECIFIED
Validation Mode: AUTO
Jar files URLs []
Managed classes names []
Mapping files names []
Properties [
hibernate.dialect: org.hibernate.dialect.MySQLDialect]