Hibernate @One mapping: NullPointer, приводящий к исключению SingleTableEntityPersister - PullRequest
0 голосов
/ 23 января 2019

У меня есть сопоставление @Any для объекта Hibernate, в котором используются дискриминаторы.В старой кодовой базе это выглядело примерно так (я скрыл имена объектов):

<any id-type="long" name="medicalProfessional" meta-type="string" >
    <meta-value value="M" class="com.borderconnect.app.domain.company.crew.MedicalProfessional"/>
    <meta-value value="D" class="com.borderconnect.app.domain.company.crew.Doctor"/>
    <column name="class_type"/>
    <column name="medical_professional_id"/>
</any>

Теперь я сопоставил что-то вроде этого (я скрыл имена объектов):

public class SomeClass extends DomainObject {
    @AnyMetaDef( name = "medicalProfessional", idType="int4", metaType="string", metaValues = {
    @MetaValue( value="M", targetEntity = MedicalProfessional.class ),
    @MetaValue( value="D", targetEntity = Doctor.class )
    })
    @Any( metaColumn = @Column( name="class_type" ), metaDef = "medicalProfessional")
    @JoinColumn( name="medical_professional_id" )
    private MedicalProfessional medicalProfessional;

Насколько я могу судить, все остальное, что связано с этим, настроено правильно.MedicalProfessional является @MappedSuperclass и имеет свой собственный стол.Доктор является организацией и расширяет MedicalProfessional и использует ту же таблицу.Кроме этого, классы тривиальны.

Когда я запускаю весеннюю загрузку, я получаю исключение "org.hibernate.MappingException: Не удалось создать экземпляр persister org.hibernate.persister.entity.SingleTableEntityPersister".

Кажется, исключение Mapping возвращается к исключению нулевого указателя:

Caused by: java.lang.NullPointerException
at org.hibernate.tuple.entity.EntityMetamodel.indicatesCollection(EntityMetamodel.java:868) ~[hibernate-support-0.5.1.jar:?]
    at org.hibernate.tuple.entity.EntityMetamodel.indicatesCollection(EntityMetamodel.java:874) ~[hibernate-support-0.5.1.jar:?]
    at org.hibernate.tuple.entity.EntityMetamodel.<init>(EntityMetamodel.java:289) ~[hibernate-support-0.5.1.jar:?]
    at org.hibernate.persister.entity.AbstractEntityPersister.<init>(AbstractEntityPersister.java:517) ~[hibernate-support-0.5.1.jar:?]
    at org.hibernate.persister.entity.SingleTableEntityPersister.<init>(SingleTableEntityPersister.java:124) ~[hibernate-support-0.5.1.jar:?]
    at jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[?:?]
        at jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) ~[?:?]
        at jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[?:?]
        at java.lang.reflect.Constructor.newInstance(Constructor.java:488) ~[?:?]
        at org.hibernate.persister.internal.PersisterFactoryImpl.createEntityPersister(PersisterFactoryImpl.java:96) ~[hibernate-support-0.5.1.jar:?]
        at org.hibernate.persister.internal.PersisterFactoryImpl.createEntityPersister(PersisterFactoryImpl.java:77) ~[hibernate-support-0.5.1.jar:?]
        at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:348) ~[hibernate-support-0.5.1.jar:?]
        at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:444) ~[hibernate-support-0.5.1.jar:?]
        at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:879) ~[hibernate-entitymanager-5.0.12.Final.jar:5.0.12.Final]
        at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:60) ~[spring-orm-4.3.19.RELEASE.jar:4.3.19.RELEASE]

На всякий случай hibernate-support-0.5.1.jar - это одна из моих внутренних зависимостей, которая обеспечивает режим гибернации.5.0.12.

Я не вижу очевидных причин нулевых указателей или отсутствующих конструкторов в моей базе кода.Мне любопытно, что здесь может происходить.Что-то я делаю не так?Я был бы очень признателен за любую помощь.

1 Ответ

0 голосов
/ 25 января 2019

Моя проблема была idType = "int4" в @AnyMetaDef.Это должно было быть idType = "int"

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