JPA - класс неизвестных объектов - PullRequest
3 голосов
/ 02 октября 2008

Надеюсь, я смогу правильно объяснить эту проблему. У меня есть 3 класса, которые занимаются моими сущностями.

@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;
...
}

И в EJB запрос выполняется таким образом

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

Мой файл persistence.xml выглядит так:

<?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>

Я получаю эту ошибку:

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)

Я использую NetBeans 6.1 с версией Glassfish, которая поставляется с ним. MySql 5.0.

Ответы [ 4 ]

5 голосов
/ 23 июля 2010

определить эту сущность в теге класса в файле persistence.xml

1 голос
/ 02 октября 2008

В соответствии с сообщением об ошибке и тем, что я понял из вашего кода, ошибка, по-видимому, содержится в файле persistence.xml, можете ли вы быть более многословным?

0 голосов
/ 25 апреля 2017

Я решил эту проблему, создав в своем веб-приложении ContextListener, вызвав закрытие фабрики диспетчера сущностей при уничтожении контекста:

public void contextDestroyed(ServletContextEvent servletContextEvent) {
    try {
        logger.info("contextDestroyed...");
        LifeCycleManager lifeCycleManager = ServiceLocator.getLifeCycleManager();
        lifeCycleManager.closeEntityManagerFactory();

    } catch (Exception e) {
        logger.error(e.getMessage(), e);
    }
}

Я также создаю бин с именем LifeCycleManager и внутри них вызываю метод DAO, чтобы закрыть фабрику менеджера сущностей:

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);
        }
    }

Внутри DAO:

...

@Autowired
private EntityManagerFactory entityManagerFactory;

...

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

Используя это каждый раз, когда я внедряю изменения в моей среде затмения, вызывается контекст уничтожения. Надеюсь, вы могли бы помочь вам, моя среда - WebLogic Server 11gR1 и JPA 1.0.

0 голосов
/ 28 августа 2012

У меня была та же ошибка, и, в дополнение к информации выше, мой случай был проблемой ClassLoader. В моем приложении три файла. Ejb-module.jar, который зависит от app-lib.jar (библиотека, которая содержит объекты pojo и базы данных) и web-module.war, который зависит от app-lib.jar.

В развертывании app-lib.jar был дважды загружен Glassfish. Погуглив, я обнаружил, что должен скопировать app-lib.jar в «общую» библиотеку в домене glassfish. Я скопировал postgresql.jar в «domain-dir / lib» и мой app-lib.jar в «domain-dir / lib / applibs». Сделали это, приложение работало как шарм.

Использованное объяснение можно найти здесь: http://docs.oracle.com/cd/E19798-01/821-1752/beade/index.html

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...