hibernate查询出的数据和数据库不一致问题解决

      今天,遇到一个奇怪的问题,有两个顺序执行的方法,第一个方法会更新A表,第二个方法会查询A表,并根据A表的某个字段来更新B表。但是A表更新成功,B表却没有更新。

经排查,有如下现象:

1.服务启动后,第一次更新可以成功,读取数据与数据库一致。

2.第二次以后做相同操作,读取数据就与数据库不一致了。

3.重启服务,再进行操作,还是第一次可以成功,再执行就不行了。

根据以上现象初步认为是读到了脏数据,再试,确认是读了上一次的数据,因为用的是hibernate,对这个并不了解,但是在操作数据层看到了session,查询资料了解到,读到的数据是缓存中的数据。

想到两种解决方法:

1.在方法1的dao的实现层的相应更新方法中,执行完更新操作后,执行一下session.flush(),作用就是将session的缓存中的数据与数据库同步。

String sql = "UPDATE A SET col_1=:col1 where col_2=:col2";
Session innerSession = getCurrSession();
innerSession.createSQLQuery(sql).setString("col1",col1).setString("col2",col2).executeUpdate();
innerSession.flush();

2.在方法2更新前进行查询时,执行查询操作前,执行一下session.clear(),作用就是清除session中的缓存数据(不管缓存与数据库的同步)。

 String sql = "from " +TEST.class.getName() + " where COL_1=:col1";
 Session innerSession = getCurrSession();
 innerSession.clear();
 List<TEST> list = innerSession.createQuery(sql).setString("col1", col1).list();

这样处理后,问题就解决了,之前的操作真的就是简单的增删改查,如果不遇到问题,应该不会去了解这些,还是要不断学习啊啊啊,啊菜鸟

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值