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

本文介绍了在使用mybatisPlus 3.1.0时遇到的分页查询返回相同数据的问题,原因是mybatis的一级缓存机制。当在同一个sqlSession内,多次调用相同的分页查询方法,由于参数未变化,mybatis会从缓存中获取数据,导致每次查询结果相同。为解决此问题,可以在DAO.xml的select标签中添加相关属性来避免使用一级缓存。
摘要由CSDN通过智能技术生成

一、问题描述

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

 

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

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

 

      会取一级缓存的条件:

1、同一个 sqlSession

2、同一个 Mapper 方法

3、参数没有发生变化

 

三、问题原因

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

 

附图:

image.png

 

image.png

 

四、解决办法

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

 

五、参考链接

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值