Con suerte, puedo explicar este problema correctamente. Tengo 3 clases que se ocupa de mi entidades.

@MappedSuperclass
public abstract class Swab implements ISwab {
...
    private Collection<SwabAccounts> accounts;
...
}

@Entity
@Table(name="switches")
@DiscriminatorColumn(name="type")
@DiscriminatorValue(value="DMS500")
public class DmsSwab extends Swab implements ISwab, Serializable {
...
    private ObjectPool pool;
...
    @Transient 
    public ObjectPool getPool(){
        return pool;
    }
...
}

@Entity(name="swab_accounts")
public class SwabAccounts implements Serializable {
    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private int swab_account_id;
    private int swab_id;
...
}

Y en un EJB una consulta se está haciendo de esta manera

    DmsSwab dms = em.find(DmsSwab.class, 2);
    List<Swab> s = new ArrayList<Swab>(1);
    s.add(dms);

Mi persistence.xml se parece a esto:

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.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_1_0.xsd">
  <persistence-unit name="dflow-pu" transaction-type="RESOURCE_LOCAL">
    <provider>oracle.toplink.essentials.PersistenceProvider</provider>
    <class>com.dcom.sap.dms.DmsSwab</class>
    <class>com.dcom.sap.jpa.SwabAccounts</class>
    <properties>
      <property name="toplink.jdbc.user" value="dflow"/>
      <property name="toplink.jdbc.password" value="dflow"/>
      <property name="toplink.jdbc.url" value="jdbc:mysql://itcd-400447:3306/dflow"/>
      <property name="toplink.jdbc.driver" value="com.mysql.jdbc.Driver"/>
    </properties>
  </persistence-unit>
</persistence>

Me sale este error:

java.lang.IllegalArgumentException: Unknown entity bean class: class com.dcom.sap.dms.DmsSwab, please verify that this class has been marked with the @Entity annotation.
com.dcom.sap.SwabException: java.lang.IllegalArgumentException: Unknown entity bean class: class com.dcom.sap.dms.DmsSwab, please verify that this class has been marked with the @Entity annotation.
Caused by: java.lang.IllegalArgumentException: Unknown entity bean class: class com.dcom.sap.dms.DmsSwab, please verify that this class has been marked with the @Entity annotation.
        at oracle.toplink.essentials.internal.ejb.cmp3.base.EntityManagerImpl.findInternal(EntityManagerImpl.java:306)
        at oracle.toplink.essentials.internal.ejb.cmp3.EntityManagerImpl.find(EntityManagerImpl.java:148)

Estoy corriendo netbeans 6.1 con la versión de glassfish que viene con él. MySql 5.0.

InformationsquelleAutor arinte | 2008-10-01

4 Comentarios

  1. 5

    definir esta entidad en la clase de la etiqueta en el interior de la persistence.xml

  2. 1

    De acuerdo con el mensaje de error y lo que la figura de su código, el error parece estar en el persistence.xml archivo, puede ser un poco más detallado ?

    • He encontrado la respuesta. Netbeans/glassfish necesita algún trabajo de lo que parece. Tuve que retirar, dejar el servidor y reiniciar y, a continuación, funcionó bien.
    • asegúrese de que usted cierre su EntityManagerFactory en undeploy
  3. 0

    Yo tenía el mismo error y, para complementar la información anterior, en mi caso fue un problema del cargador de clases. Mi aplicación tiene tres archivos. Un ejb-module.jar que depende de la app-lib.jar (biblioteca que contiene pojo y entidades de bases de datos) y un módulo web.la guerra que depende de la app-lib.jar.

    En la implementación, la app-lib.jar se ha cargado dos veces por el servidor glassfish. Buscando en google, encontré que debía copiar el app-lib.jar a un «compartida» lib en el servidor glassfish dominio. He copiado el postgresql.jar «domain-dir/lib» y mi app-lib.jar «domain-dir/lib/applibs». Lo han hecho, la aplicación trabajó como un encanto.

    El utilizado explicación se puede encontrar aquí: http://docs.oracle.com/cd/E19798-01/821-1752/beade/index.html

  4. 0

    He resuelto este problema creando un ContextListener en mi Web App, invocando el cierre de la entidad administrador de la fábrica a destruir contexto, :

    public void contextDestroyed(ServletContextEvent servletContextEvent) {
        try {
            logger.info("contextDestroyed...");
            LifeCycleManager lifeCycleManager = ServiceLocator.getLifeCycleManager();
            lifeCycleManager.closeEntityManagerFactory();
    
        } catch (Exception e) {
            logger.error(e.getMessage(), e);
        }
    }

    Yo también crear un bean con el nombre LifeCycleManager y dentro de ellos invocar un método de DAO para cerrar el administrador de la entidad de fábrica:

    public void closeEntityManagerFactory() throws BusinessException {
            logger.info("closeEntityManager");
            try {
                logger.info("closing entity manager factory...");
                genericDAO.closeEntityManagerFactory();
                logger.info("Entity manager factiry closed");
            } catch (Exception e) {
                throw new BusinessException(BusinessErrorCode.CODIGO_EJEMPLO_01, Severity.ERROR);
            }
        }

    Dentro del DAO:

    @Autowired
    private EntityManagerFactory entityManagerFactory;

    public void closeEntityManagerFactory() {
            logger.info("closing entity manager factory");
            getEntityManagerFactory().close();
            logger.info("entity manager factory closed");   
        }

    El uso de este cada vez que me implementar un cambio de mi entorno eclipse el destruir contexto se invoca.
    Espero que podrían ayudar a ustedes, mi entorno es el Servidor WebLogic 11gR1 y JPA 1.0.

Dejar respuesta

Please enter your comment!
Please enter your name here