5

我有SessionsUsers具有以下bi-directional OneToMany映射的类(使用休眠逆向工程工具生成):

public class Users {
    @OneToMany(fetch=FetchType.LAZY, mappedBy="users")
    public Set<Sessions> getSessionses() {
        return this.sessionses;
    }
}

public class Sessions {
    @ManyToOne(fetch=FetchType.LAZY)
    @JoinColumn(name="USER_ID")
    public Users getUsers() {
        return this.users;
    }
}

这是我为用户创建新会话的代码:

Session s = ...;
Users user = (Users) s.createCriteria(Users.class)
             ./*restrictions...*/.uniqueResult();
Sessions userSession = new Sessions();
userSession.setUsers(user);
s.save(userSession);
user.getSessionses().add(userSession); // here getSessionses() has 2k records

用户有 2k 个会话,因此最后一行非常慢。

如何在不获取整个会话集合的情况下将会话与用户链接?

4

2 回答 2

4

看看 Hibernate 的超延迟加载功能。您可以通过使用 注释您的集合来启用它@LazyCollection(LazyCollectionOption.EXTRA)。有这个例子可以看,也有在这个Set例子中使用。

public class Users {
    @OneToMany(fetch=FetchType.LAZY, mappedBy="users")
    @LazyCollection(LazyCollectionOption.EXTRA)
    public Set<Sessions> getSessionses() {
        return this.sessionses;
    }
}
于 2013-05-15T10:29:33.780 回答
1

我不确定 hibernate 是否会以两种方式添加此连接,而是将 a 添加Session到 a 的User集合UserSession。这样您就不必加载每个会话。

于 2013-05-15T10:17:23.117 回答