mybatisPlus分页查询多次查到相同数据的问题

一、问题描述

      使用 mybatisPlus 3.1.0,在同一个方法内,多次调用同一个方法进行分页查询,每次查询的分页页码递增,结果每次查到的数据都一样。

 

二、相关知识:mybatis 一级缓存

      mybatis存在缓存机制,查询到的数据会纳入缓存,同一sqlSession共享的叫一级缓存。默认情况下,mybatis会使用一级缓存

 

      会取一级缓存的条件:

1、同一个 sqlSession

2、同一个 Mapper 方法

3、参数没有发生变化

 

三、问题原因

      mybatis 判断是否需要使用一级缓存的代码,早于 mybatisPlus 分页插件拦截的代码执行(分页代码早一点执行,才有机会将分页参数也作为是否取缓存的依据)

 

附图:

mybatisPlus分页查询多次查到相同数据的问题_第1张图片

 

mybatisPlus分页查询多次查到相同数据的问题_第2张图片

 

四、解决办法

在 DAO.xml 对应的 select 标签里,增加属性 flushCache="true"​

 

五、参考链接

https://www.cnblogs.com/fangjian0423/p/mybatis-cache.html

你可能感兴趣的:(java)