这个问题困扰我有一段时间了,问题应用的场景是:
数据库有三张表,两两之间是互相关联的,关联的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语句就会去找缓存而不是再去查一次数据库