SSH框架整合之级联删除所发生的异常

本文探讨了在使用Hibernate框架进行数据库操作时遇到的级联删除错误,详细分析了错误产生的原因,包括数据库外键约束和配置缺失,并提供了解决方案,通过正确配置set标签实现级联删除。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当数据库有一对多关系的时候,删除1方数据的时候必须先删除多方数据(或者把数据库1的一方表的表外键指控),当我们使用SSH框架开发的时候,hibernate已经帮我们做好级联删除了,只需要在set标签上加cascade=“delete”,就可以做级联删除了,但是我今天做练习的时候出现这个错误。could not execute statement; SQL [n/a]; constraint [null]; nested exception is org.hibernate.except
在这里插入图片描述
这是一个外键错误,我在网上找了很多原因(在这里简单列几个):
① 是因为数据库还有其他表的外键指向该表的主键
② 是因为set标签上缺了一个配置。
下面是我set标签上的配置 。

<set name="linkMans" cascade="delete" inverse="true">
            <key column="lkm_cust_id" />
          <one-to-many class="com.crm.domain.LinkMan"/>

这样就解决了,特此记录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值