public void delete(MenuModel mm) {
//完成级联删除的前提是,被删除对象级联的数据存在
//删除OID为4的数据时,对应的对象应该级联哪些必须是已知的,此时对象中的关系数据存在
//mm对象此时具有哪些数据?只有uuid,关系数据为null
//h3对于关系数据为空的处理方式是:断开所有关系即可,(把外键置空)由于此时设置了inverse=true,又不维护关系,没有进行任何操作
//解决方案:级联删除前加载关系
MenuModel temp = menuDao.get(mm.getUuid());
//temp对象此时就具有了延迟加载功能,可以随时加载关系
menuDao.delete(temp);}
//当进行级联删除时 一方对象首先要放弃与多方之间的关系,
//转化为将外键字段设置为null 如果此时外键字段设置为不允许为null,
//引发下列异常 Caused by: java.sql.BatchUpdateException: Column 'puuid' cannot be n
//此时只需要在进行关系维护时,使一方对象不对关系进行维护即可,不操作外键————inverse=true
<set name=children cascade=delete inverse=true />
<key column=puuid/>
<one-to-many class=erp.auth.menu.vo.MenuModel/>
</set>