SSH级联删除问题

2 篇文章 0 订阅

1.数据库有两张表 department表 和 employee表:department中有外键 did于employee中的did对应. department里是部门情况。employee是雇员信息,一个部门有多条雇员信息。
2.问题是:
我删除一条部门信息。对应着的该部门也被删了。而该部门所在的另外信息雇员还在、这样显示的时候就报错了。
3. Department.hbm.xml

<set name="employees" table="EMPLOYEE" inverse="false" cascade="delete">
            <key>
                <column name="DID" />
            </key>
            <one-to-many class="com.employee.domain.Employee" />
</set>

需要加上cascade="delete"这是关键
4.Employee.hbm.xml

<many-to-one name="department" class="com.employee.domain.Department">
            <column name="DEPARTMENT" />
</many-to-one>

5.在Action中的删除代码,首先是查找实体,在删除实体

public String delete(){
        //通过这一步可以进行级联操作
        department=departmentService.findById(department.getDid());
        departmentService.delete(department);
        return "deleteSuccess";
}

6.我所使用的是Mysql,需要在外键上删除上设置CASCADE,如图
这里写图片描述
我遇到最大的问题就是这呢,根本就不知道这里有错,耗费了好久

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值