考虑实体

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);
  }

}


我的问题是,为什么对实体用户的简单查询会自动触发查询以初始化SocialCredential的实体列表? @Transaction有什么问题吗?我对EAGERLY加载列表SocialCredential不感兴趣。

最佳答案

您遇到的错误是非常常见的休眠错误。

List<SocialCredential> credentialsList = new ArrayList<SocialCredential>();

您需要获取该列表,可以使用另一个查询来获取该特定列表,并将其设置为用户Object。

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;

07-24 09:27