Ошибка доступа к полю гибернации, проблемы с отображением - PullRequest
1 голос
/ 03 февраля 2020

Я пытаюсь реализовать hibernate и смотрю на один из моих старых проектов, который использует аннотации. Я хочу иметь многоцветное отображение. Вот классы.

Класс, используемый для хранения ListItems, содержит ссылку на все элементы внутри него, которые я сейчас пытаюсь отобразить.

См. private List<ListItem> listItems

@Entity
@Table(name = "ITEMLIST")
public class ItemList {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private UUID listId;
    @Column(unique = true)
    private String name;
    @Enumerated(EnumType.STRING)
    private ListTypes listType;
    @OneToMany(mappedBy = "itemList")
    private List<ListItem> listItems;
    @Column(unique = true)
    private int position;

Класс ListItem, который хранит ссылку на список, в котором он находится в данный момент.

См. private ItemList itemList;

@Entity
@Inheritance
@DiscriminatorColumn(name = "ITEMTYPE")
@Table(name = "LISTITEM")
public abstract class ListItem {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private UUID itemId;
    @ManyToOne
    @JoinColumn
    private ItemList itemList;
    private String url;
    private String name;
    private Date dateAdded;
    private int position;

Тестовый код, используемый для проверки персистентности:

    public ItemList createList(){
        Session session = factory.openSession();
        ItemList itemList = new ItemList();
        session.save(itemList);
        factory.close();
        return itemList;
    }

Что дает мне этот журнал ошибок:

Exception in thread "restartedMain" java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49)
Caused by: org.hibernate.property.access.spi.PropertyAccessException: Error accessing field [private java.util.List<xxx.listorganizer.listorganizer.Interfaces.ListItem> xxx.listorganizer.listorganizer.Models.ItemList.listItems] by reflection for persistent property [xxx.listorganizer.listorganizer.Models.ItemList#listItems] : xxx.listorganizer.listorganizer.Models.ItemList@7955d081
    at org.hibernate.property.access.spi.GetterFieldImpl.get(GetterFieldImpl.java:75)
    at org.hibernate.property.access.spi.GetterFieldImpl.getForInsert(GetterFieldImpl.java:90)
    at org.hibernate.tuple.entity.AbstractEntityTuplizer.getPropertyValuesToInsert(AbstractEntityTuplizer.java:570)
    at org.hibernate.tuple.entity.PojoEntityTuplizer.getPropertyValuesToInsert(PojoEntityTuplizer.java:226)
    at org.hibernate.persister.entity.AbstractEntityPersister.getPropertyValuesToInsert(AbstractEntityPersister.java:5170)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:271)
    at org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:198)
    at org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:128)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.saveWithGeneratedOrRequestedId(DefaultSaveOrUpdateEventListener.java:193)
    at org.hibernate.event.internal.DefaultSaveEventListener.saveWithGeneratedOrRequestedId(DefaultSaveEventListener.java:38)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.entityIsTransient(DefaultSaveOrUpdateEventListener.java:178)
    at org.hibernate.event.internal.DefaultSaveEventListener.performSaveOrUpdate(DefaultSaveEventListener.java:32)
    at org.hibernate.event.internal.DefaultSaveOrUpdateEventListener.onSaveOrUpdate(DefaultSaveOrUpdateEventListener.java:75)
    at org.hibernate.event.service.internal.EventListenerGroupImpl.fireEventOnEachListener(EventListenerGroupImpl.java:108)
    at org.hibernate.internal.SessionImpl.fireSave(SessionImpl.java:618)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:611)
    at org.hibernate.internal.SessionImpl.save(SessionImpl.java:606)
    at xxx.listorganizer.listorganizer.DAOs.ListDAO.createList(ListDAO.java:21)
    at xxx.listorganizer.listorganizer.ListorganizerApplication.main(ListorganizerApplication.java:14)
    ... 5 more
Caused by: java.lang.IllegalArgumentException: Can not set java.util.List field xxx.listorganizer.listorganizer.Models.ItemList.listItems to xxx.listorganizer.listorganizer.Models.ItemList
    at ...

Надеюсь, кто-то может помочь:)

Ответы [ 2 ]

0 голосов
/ 05 февраля 2020

Оказывается, это связано со мной, используя UUID для генерации идентификатора. Поменяв это на долго исправил.

0 голосов
/ 03 февраля 2020

Я думаю, что он не может создать объект вашего абстрактного класса

...