0

我有一个名为 User 的实体类,其中包含数据库的 OneToMany 列:

  @Setter
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "user")
    @JoinTable(
        name = "USER_CARS",
        joinColumns = @JoinColumn(name="USER_ID", referencedColumnName = "id"),
        inverseJoinColumns = @JoinColumn(name="CAR_ID", referencedColumnName = "id")
    )
    private List<Car> cars;

当我将用户插入数据库时​​,一切正常,他的汽车也被添加到 user_cars 表中。检索汽车时,我收到此异常:

Method threw 'org.hibernate.LazyInitializationException' exception.

我已经搜索了其他答案,但没有找到解决方法。这就是我试图检索用户的方式。

public T findById(Long id) {
    em = emf.createEntityManager();
    em.getTransaction().begin();

    T et = (T) em.find(entityClass, id);

    em.getTransaction().commit();
    em.close();

    return et;
}

有什么问题,我该如何解决?我无法理解后台发生了什么。

4

1 回答 1

1

根据异常消息,您似乎正在检索List汽车的内容,但EntityManager会话已经关闭。而不是您可以使用的集合的默认延迟初始化

@OneToMany(cascade = CascadeType.ALL, mappedBy = "user", fetch = FetchType.EAGER)
于 2014-06-02T12:08:08.333 回答