您的位置:首页 > 其它

hibernate做数据同步时的问题

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

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

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

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

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

在实验过程中还发现一个问题,就是如果先删除一个对象,后面要保存的对象的主键值和前面被删对象一致,那么在执行save时就会向mysql发送delete语句,而不需要flush。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐