考虑实体
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);
}
}
我的问题是为什么实体User的简单查询会自动触发查询来初始化SocialCredential的实体列表? @Transaction有什么问题。我对EAGERLY加载列表SocialCredential不感兴趣。
答案 0 :(得分:0)
您遇到的错误是一种非常常见的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;