错误现象:Project和User使用注解多对一单向关联(@ManyToOne)
// Project 类
@ManyToOne
@JoinColumn(name = "user_id", nullable = false)
private User user;先new一个Project对象,并从数据库中取出User对象放入Project对象
此时使用session.save(project)报错:On release of batch it still contained JDBC statements
错误分析:由于user对象是从数据库中取出,还缓存在session中,此时save(project)就报错
解决办法:配置Cascade注解就可以了
@ManyToOne
@Cascade(value = CascadeType.SAVE_UPDATE) // 增加该注解即可
@JoinColumn(name = "user_id", nullable = false)
private User user;解决办法二:用
session.merge()方法代替session.save()即可
版权声明:本文为qq12547345原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。