关于hibernate的More than one row with the given identifier was found报错原因和处理

项目中没有事务控制,以至于客户在网络不好的情况下,多次点击,造成表单重复提交。

More than one row with the given identifier was found——从百度和其他博客上不难得知,这是hibernate映射的表,在原本1对1的情况下,变成了1对多抛出的异常。

比如主表A和从表B中的数据,原本由A.id=B.baseId变成了A.id=B1.baseId,A.id=B2.baseId这样的情况。

解决方式也很简单,删除多余的数据,恢复原本的1对1映射状态。

不过值得一提的是,假设从表B还有一个从表C,两者也是1对1的映射关系,那么还需要删除从表C中对应的数据。

网上其他博客,我看了一些,大多都是让直接删除整张表,然后重新导入数据,不过我没那么做,而是一条条的找到,然后删除。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值