Hibernate NullPointerException при использовании критериев в сеансе EntityMode.DOM4J - PullRequest
3 голосов
/ 09 июня 2009

Я сталкиваюсь с исключением нулевого указателя, если я пытаюсь использовать следующий код:

//Spring JPA entityManager allow us to retriver the underlying session.
org.hibernate.Session session = (org.hibernate.Session)entityManager.getDelegate();
org.hibernate.Session dom4jSession = session.getSession(org.hibernate.EntityMode.DOM4J);

org.hibernate.Criteria c = session.createCriteria(User.class);
c.list();

Я получаю следующее исключение:

java.lang.NullPointerException
    at org.hibernate.type.EntityType.getIdentifierType(EntityType.java:520)
    at org.hibernate.type.EntityType.setToXMLNode(EntityType.java:377)
    at org.hibernate.property.Dom4jAccessor$ElementSetter.set(Dom4jAccessor.java:333)
    at org.hibernate.tuple.component.AbstractComponentTuplizer.setPropertyValues(AbstractComponentTuplizer.java:104)
    at org.hibernate.type.ComponentType.setPropertyValues(ComponentType.java:381)
    at org.hibernate.type.ComponentType.resolve(ComponentType.java:609)
    at org.hibernate.type.ComponentType.nullSafeGet(ComponentType.java:298)
    at org.hibernate.persister.collection.AbstractCollectionPersister.readElement(AbstractCollectionPersister.java:725)
    at org.hibernate.collection.PersistentElementHolder.readFrom(PersistentElementHolder.java:125)
    at org.hibernate.loader.Loader.readCollectionElement(Loader.java:1031)
    at org.hibernate.loader.Loader.readCollectionElements(Loader.java:669)
    at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:614)
    at org.hibernate.loader.Loader.doQuery(Loader.java:724)
    at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:259)
    at org.hibernate.loader.Loader.loadCollection(Loader.java:2015)
    at org.hibernate.loader.collection.CollectionLoader.initialize(CollectionLoader.java:59)
    at org.hibernate.persister.collection.AbstractCollectionPersister.initialize(AbstractCollectionPersister.java:587)
    at org.hibernate.event.def.DefaultInitializeCollectionEventListener.onInitializeCollection(DefaultInitializeCollectionEventListener.java:83)
    at org.hibernate.impl.SessionImpl.initializeCollection(SessionImpl.java:1743)
    at org.hibernate.type.CollectionType.getCollection(CollectionType.java:646)
    at org.hibernate.type.CollectionType.resolveKey(CollectionType.java:430)
    at org.hibernate.type.CollectionType.resolve(CollectionType.java:424)
    at org.hibernate.engine.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:139)
    at org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:877)
    at org.hibernate.loader.Loader.doQuery(Loader.java:752)

Строка 520 org.hibernate.type.EntityType содержит следующее:

return factory.getIdentifierType( getAssociatedEntityName() );

Кажется, что заводской объект нулевой .... Почему ???

1 Ответ

0 голосов
/ 04 января 2012

Можете ли вы опубликовать свой файл сопоставления? Также проверьте, есть ли в файле сопоставления информация об узле и типе. Эта ссылка может вам помочь.

http://docs.jboss.org/hibernate/core/3.3/reference/en/html/xml.html

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