hibernate做数据同步时的问题

当我们有做数据同步需求时,如果表中除了主键不能重复,还有其他字段比如名称不能重复,那么在做同步时可能会出现以下情况:

A平台上数据已经删除,此时B平台的数据库还未同步,这时A平台新增了一个名称与原来一样的资源。这时B平台开始做数据同步,不巧的是,删除操作在添加操作之后,那么会出现无法保存名字相同的数据。那么该怎么办?

解决方法就是先做删除,后做保存。但由于hibernate机制问题,在批量操作后,使用一个commit,会先发送save语句,导致报错。那么该怎么办?

解决方法就是先做删除,并使用session.flush。后做保存,最后再commit。

/flush的作用是发送语句到mysql,让mysql中状态与session一致,但不清缓存,在mysql的一个会话中, 数据是一条一条处理的,一旦前一条删除,后一条即使与前一条主键相同,那也是能插入的。不用flush,那么最终是由commit方法中的flush来发送语句,但是会发现delete没有先执行,而是save先执行。

在实验过程中还发现一个问题,就是如果先删除一个对象,后面要保存的对象的主键值和前面被删对象一致,那么在执行save时就会向mysql发送delete语句,而不需要flush。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值