hibernate之saveorupdate()、save()、update()都有什么区别, 为什么saveorupdate不能更新成功或卡死

本文探讨了在数据库操作中,save()和saveOrUpdate()的区别,特别强调了主键自动生成时的注意事项,包括如何处理插入和更新,事务、关联对象保存问题,以及根据where条件更新时可能出现的错误。同时提到了各种场景下选择save或saveOrUpdate的方法论。
摘要由CSDN通过智能技术生成

saveorupdate()如果传入的对象在数据库中有就做update操作,如果没有就做save操作。
save()在数据库中生成一条记录,如果数据库中有,会报错说有重复的记录。
update()就是更新数据库中的记录。

当你的主键是自己分配的时候 就不能使用saveorupdate()了,否则会报 Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1 这个错误。这时只能使用save()方法直接保存了。

     save方法更适用于确定了是要插入,而且需要得到插入数据的主键。
而saveOrUpdate更倾向于不缺定是插入还是更新,而且你不需要得到他的主键。

save()和saveOrUpdate()方法可以在没有事务的情况下执行,但是如果没有手动调用flush()方法会面临关联对象不被保存的问题。

还有 saveOrUpdate修改数据库数据时,如果 根据where条件能检索到两条以上的数据,那么执行update也会报错。 而此时,删除多余的数据只保留一条就可以解决了 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值