在做信息和附件一对多关系关联删除的时候,遇到了问题,当删除一个信息的附件的时候,信息的附件会自动的复制一份;而且这个自动复制的附件没有对应的信息的编号就是外键;网上查了解决了问题;
当一对多删除多方对象的时候,要先将要删除的多方和一方先解除关系,然后才能删除多方;这样就不会报错;
Action中的代码
**********************************
public ActionForward delete(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
String pid =request.getParameter("pid");
String id =request.getParameter("id");
Post post = releaseService.findById(Integer.valueOf(pid));
//删除附件
Attachment att = attService.getById(Integer.valueOf(id));
//先解除附件和信息之间的关系 然后再删除 否则会报deleted object would be re-saved by cascade的错误
post.getAttachments().remove(att);
attService.delAtt(att);
request.setAttribute("post", post);
return mapping.findForward("show");
}
****************************************
信息的Post.hbm.xml 这个是一方 多方没有特殊的配置
************
<!-- 一条信息对应多个附件 -->
<key column="pid"></key>
<one-to-many class="worklog.bean.Attachment"></one-to-many>
************
在删除一方的时候多方将全部被删除
分享到:
相关推荐
能实现一对多关联的通用EXCEL导入功能 具体访问我的BLOG http://blog.csdn.net/dreamdiary
实现Mybatis框架中一对多关联映射的查询操作。 User用户表 - Order_form订单表属于 1-N 的关系。 一个用户对象包含一批订单信息
Mybatis实现一对一、一对多关联查询,关联查询:多个表联合查询,只查询一次,通过resultMap里面的、标签配置一对一、一对多;涉及到的一对一、一对多关系: - 班级classes、班主任teacher是一对一的关系 - 班级...
hibernate关联映射详解SSH 多对多,一对多关系对象映射
NULL 博文链接:https://dreamzhong.iteye.com/blog/1200387
本文实例讲述了MySQL 多表关联一对多查询实现取最新一条数据的方法。分享给大家供大家参考,具体如下: MySQL 多表关联一对多查询取最新的一条数据 遇到的问题 多表关联一对多查询取最新的一条数据,数据出现重复 ...
Hibernate映射一对多关联关系
MyBatis框架的学习(五)——一对一关联映射和一对多关联映射
hibernate双向一对多关联映射(注解版)
SpringBoot中mybatis表关联映射关系(一对多嵌套:结果方式)
ibatis配置多表关联(一对一、一对多、多对多
Hibernate一对多使用非主键关联设置,参看详细说明
Mybatis实现关联查询一对一和一对多实现,具体效果看博文 http://blog.csdn.net/evankaka/article/details/45674101
ibatis实战之一对多关联源代码 文章地址:http://blog.csdn.net/itmyhome1990/article/details/30050183
onetoone fk 一对一外键关联带数据库。 onetoone fk 一对一外键关联带数据库。 onetoone fk 一对一外键关联带数据库。
hibernate双向一对多关联映射(XML)
一个hibernate一对多关联实例,包括关联save、关联delete、关联select、关联update。
Hibernate一对多双向自身关联demo代码
NULL 博文链接:https://dreamzhong.iteye.com/blog/1200915
Hibernate双向一对一关联映射(注解版)