我有Sessions
和Users
具有以下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 个会话,因此最后一行非常慢。
如何在不获取整个会话集合的情况下将会话与用户链接?