休眠错误访问字段,映射问题

时间:2020-02-03 19:58:00

标签: java spring hibernate jpa persistence

我正在尝试实现休眠状态,并正在查看使用注释的旧项目之一。我想有一个多音映射。这是课程。

以前用于保存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 :(得分:0)

我认为它无法创建抽象类的对象

答案 1 :(得分:0)

原来,这与使用UUID生成ID有关。将此更改为长期修复。

相关问题