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,如图
我遇到最大的问题就是这呢,根本就不知道这里有错,耗费了好久