在同一事务中,mybatis多次查询返回相同结果解决方法

这个问题困扰我有一段时间了,问题应用的场景是:

数据库有三张表,两两之间是互相关联的,关联的ID就是各个Table中的主键ID;涉及多表的关系插入,显然在创建表的时候,表的主键ID不能设置成自增(MySql下,auto_increament)键,而且自增主键在并发的场景下,同一时刻如果产生了两个一样的主键ID,是不是insert的时候服务就要崩掉了,就算在事物控制下也会造成用户数据的丢失,非常不友好。怎么办呢?

于是乎,我想到了用MySql的序列sequence,我建立了一个全局序列表--sequence,显然三张表的主键ID全部来自于此序列表,不管你怎么来,执行一次select序列表查询,取出的序列值都是不一样的(并发下未做测试,应该能应对)

一、问题描述:

使用spring @Transaction事务时,在for循环中需要多次执行同一查询语句,第一次查询出对象后,对对象进行修改后,结果再进行第二次查询的时候,查询返回的数据是自己第一次修改后的数据。因为业务需要每次查询都需要取更改数据库,以后的查询都会根据上一次循环修改后的值进行操作。

二、解决方法:

(1)在xml文件 select语句添加  flushCache="true"  ,告诉mybatis查询结束后刷新缓存,不记录查询结果到一级缓存中

<select id="pageListCount" resultType="int" flushCache="true">
(2)本来想找全局配置的方法,但是在网上找到mybatis关闭缓存的属性,但是配置上都不起作用,只有第一种方法好用,这里就不写了

三、原因:

mybatis有一级缓存和二级缓存,mybatis对查询的语句会存在一级缓存中,如果在一个事务中,mybatis对同一个session多次查询同一个sql语句就会去找缓存而不是再去查一次数据库

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值