考虑实体
public class User {
...
@OneToMany(cascade = CascadeType.ALL)
List<SocialCredential> credentialsList = new ArrayList<SocialCredential>();
}使用DAO实现方法
@Transactional
@Override
public User getUser(long id){
Session s = sessionFactory.getCurrentSession();
User asu = (User) s.get(User.class, id);
return asu;
}和控制器
@Controller
public class DummyController {
@Autowired
UserDAO userDAO;
public void anyMethodAccessedByGetORPost(){
User u= userDAO.getUser(1L);
}
}我的问题是,为什么一个实体用户的简单查询会自动触发query来初始化SocialCredential的实体列表?@Transaction.I有什么问题吗?我不想急于加载列表SocialCredential。
发布于 2015-10-23 22:41:34
您遇到的错误是一个非常常见的Hibernate错误。
List<SocialCredential> credentialsList = new ArrayList<SocialCredential>();
您需要获取该列表,您可以使用另一个查询来获取该特定列表,并将其设置为您的用户对象。
Session s = sessionFactory.getCurrentSession();
list credentialsList = this.getCredentialsList();
User asu = (User) s.get(User.class, id);
asu.setCredentialsList(credentialsList);
return asu;有时工作的另一种方式是:
Session s = sessionFactory.getCurrentSession();
User asu = (User) s.get(User.class, id);
**adding this line **
asu.getCredentialsList.get(0);
return asu;https://stackoverflow.com/questions/33303989
复制相似问题