2008-10-01 3 views
3

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

@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 с версией gla ssfish, который поставляется вместе с ним. MySql 5.0.

ответ

1

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

+1

Я нашел ответ. Netbeans/glassfish нуждается в некоторой работе. Мне пришлось отменить развертывание, остановить сервер и перезапустить, а затем он работал нормально. – arinte 2008-10-03 14:31:44

5

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

0

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

В развертывании приложение-lib.jar было загружено дважды стеклянной фишкой. Googling, я узнал, что должен скопировать приложение 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

0

Я решил эту проблему создавая ContextListener в моей Web App, ссылаясь на закрытии менеджера предприятия завода по уничтожению контекста,:

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

Insid е дао:

...

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

 Смежные вопросы

  • Нет связанных вопросов^_^