EAR中的实体未知,持久单元在另一个容器中



我有一个EAR,其中包含一个WAR模块、一些EJB模块和一些jar,例如:

EAR
 - moduleEjb.jar
 - moduleWeb.war
 -lib
      - entity.jar
      - resource.jar

我想使用resource.jar中的持久单元,这样ejb模块就独立于环境(我必须只记住PU名称,我可以在resource.jar中更改数据源的jndi而不更改moduleEjb.jar),但是没有找到实体。

实体在entity.jar:

@Entity
@Table(name = "ttracciatikettle", indexes = {...})
@NamedQueries({...})
public class TTracciatoKettle extends EntityBaseGest implements Serializable { ... }

持久性单元在resource.jar

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd">
<persistence-unit name="myPU" transaction-type="JTA">
    <provider>org.eclipse.persistence.jpa.PersistenceProvider</provider>
    <jta-data-source>java:/jboss/datasource/mydata</jta-data-source>
    <jar-file>../entity.jar</jar-file>
    <properties>
        <property name="javax.persistence.schema-generation.database.action" value="create"/>
        <property name="eclipselink.logging.logger" value="org.eclipse.persistence.logging.DefaultSessionLog"/>
        <property name="eclipselink.logging.level" value="ALL"/>
        <property name="eclipselink.logging.level.sql" value="ALL"/>
        <property name="javax.persistence.sql-load-script-source" value="META-INF/defaultdata.sql"/>
    </properties>
</persistence-unit>

和实体管理器在EJB中的moduleEjb.jar中使用:

@PersistenceContext(unitName = "myPU")
private EntityManager em;
@Override
public TTracciatoKettle findByCodice(String codice) throws BadRequestException{
    try{
        //return this.em.createNamedQuery("TTracciatoKettle.findByCodice", entityClass)
        return this.em.createQuery("SELECT t FROM TTracciatoKettle t WHERE t.codice = :codice", entityClass)
                .setParameter("codice", codice)
                .getSingleResult();
    }catch(NoResultException ne){
        return null;
    }catch(NonUniqueResultException nure){
        ...
    }
}

即使我使用命名查询或jpql,我得到错误

[14,30]抽象模式类型' ttracciatkettle '是未知的。

[39,47]状态字段路径't.codice'无法解析为有效类型。

持久化单元myPU被启动,加载脚本也被成功调用。如果我使用相同的PU,但在ejb模块内,它工作

根据目录结构,你发布的jar entity.jarresource.jar在同一个目录:lib。所以persistence.xml文件中的jar-file条目应该是:

<jar-file>entity.jar</jar-file>

代替

<jar-file>../entity.jar</jar-file>
对于ear文件的lib目录中的持久性存档(在META-INF目录下包含persistence.xml的jar),持久性单元myPU应该对ear中的所有组件可见。下面是稍微修改过的目录布局:
EAR
   moduleEjb.jar
   moduleWeb.war
   lib
      entity.jar
      resource.jar
          META-INF  // in the root of the jar file
              persistence.xml

相关阅读:第8章:JPA 2.1规范的实体封装

相关内容

最新更新