mybatis 分页查询配置(mybatis-plus分页传入参数后sql where条件没有limit分页信息操作)
mybatis 分页查询配置
mybatis-plus分页传入参数后sql where条件没有limit分页信息操作折腾了差不多两个小时,各种方法尝试,后来想想应该是where过滤后的数据量没有达到默认一页规定的数量所以干脆where就不显示limit信息了,试了一下还真是。。。这作者还真是把程序做的足够智能,可是这个智能也让我白白花掉了两个小时。。。还是自己太笨了……
但是奇怪的是,如果我不设置querywrapper参数,where后面的分页限制又是可以出来的。百思不得其解作者的想法。。。
具体看代码:
|
@override public pageutils querypage(map<string, object> params) { ipage<orderentity> page = this .page( new query<orderentity>().getpage(params), new querywrapper<orderentity>().eq(!utilstring.isnull(params.get( "user_id" )) , "user_id" , params.get( "user_id" )) ); return new pageutils(page); } |
记录的目的是希望跟我一样遇到这个特殊情况的童鞋能快速绕过这个弯,时间宝贵。晚安^.^
最后附上官方文档,希望大家多看看文档系统性的了解
https://mp.baomidou.com/guide/dynamic-datasource.html
补充知识:记录逆向工程生成的mybatisplus分页方法limit失效的坑
因为我在解决问题之前也是在网上查找方法和官网查找方法都有没有解决,所以也是我写这篇文章的原因,希望
后面的同学在开发的时候能够少走弯路
controller层
|
@requestmapping ( "/list" ) public r list( @requestparam map<string, object> params){ pageutils page = categoryservice.querypage(params); return r.ok().put( "page" , page); } |
传递的参数如图
server接口
|
public interface categoryservice extends iservice<categoryentity> { pageutils querypage(map<string, object> params); } |
问题及解决办法(这是网上的办法并没有解决。。。。。)
然而在查询时,分页并没有生效,查询的结果是该表中的所有数据,在pom无误的情况下,检查有没有把分页拦截器注入到spring中。
|
import com.baomidou.mybatisplus.extension.plugins.paginationinterceptor; import org.springframework.context.annotation.bean; import org.springframework.context.annotation.configuration; @configuration public class mybatisplusconfig { @bean public paginationinterceptor paginationinterceptor(){ return new paginationinterceptor(); } } |
以上是在网上找的到解决办法,我复制到项目中显示方法是过时的,而且并不生效
后来找到问题是我的mybatisplus版本 太高了,所以不支持
这个是我maven中引用的版本
然后在网上搜索的拦截器方法
采用新的分页方法问题就解决了
问题的关键是 怎么去根本查找问题,对我就是反思查找问题的方法,不至于今天浪费了1,2个小时都没有找到,就是先去官方文档.
查看官方的实例代码 !!!!!!
以下是我在gitee上查找到的逆向工程
因为项目工期非常的紧,而我拿着同事的老框架代码看着非常头疼,这个时候选择逆向工程,自己搭建一个轻量级的框架那不是爽歪歪吗?
因为项目是采用的springcloud微服务,我负责的一个系统所以可以为所欲为。
这边我使用的逆向工程是gitee上的人人开源网 renren-generator 框架
他生成的代码中没有分页方法的拦截器,我在官网上查找到方法也是过时的,这点是很坑的。
以上这篇mybatis-plus分页传入参数后sql where条件没有limit分页信息操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持开心学习网。
原文链接:https://blog.csdn.net/oceanyang520/article/details/98133008
- sql统计天数怎么算(SQL对数据进行按月统计或对数据进行按星期统计的实例代码)
- sqlserver日期型数据类型是哪个(SQL Server时间戳功能与用法详解)
- sql server数据库权限(SQL Server中通用数据库角色权限的处理详解)
- sql server 2019 资源不足不可信(SQL Server异常代码处理的深入讲解)
- mysql报错103(解决Mysql报Invalid default value for“operate_time”错误的问题)
- sqlcount优化(SQL优化教程之in与range查询)
- docker查找redis配置文件(解决docker重启redis,mysql数据丢失的问题)
- sql内连接和外连接(SQL左连接和右连接原理及实例解析)
- mysql常用优化方法(理解MySQL查询优化处理过程)
- sql中where和having可以同时用吗(SQL where条件和jion on条件的详解及区别)
- mysql删除表内所有数据(mysql 大表批量删除大量数据的实现方法)
- sqlserver去除空格函数(sqlServer实现去除字符串空格)
- SQL Server日期与字符串之间的转换
- mysql 操作日志(MySQL中的undo日志)
- sql语句的groupby是做什么的(深入浅析SQL中的group by 和 having 用法)
- mysql操作时间的函数(一篇文章搞定Mysql日期时间函数)
- 冬季钓鱼子线用 长 还是 短(冬季钓鱼子线用)
- 鱼竿 夏钓短,冬钓长 ,一定是这样 认清优缺点在选竿(鱼竿夏钓短冬钓长)
- 鲢鳙钓底还是钓浮 流水的水域应怎样做钓(鲢鳙钓底还是钓浮)
- 入秋后的第二场苹果发布会来了 全新M1系列芯片登场(入秋后的第二场苹果发布会来了)
- 苹果正式发布自研芯片M1 5nm 32核心 彻底放弃Intel(苹果正式发布自研芯片M1)
- 苹果自研芯片跑分对比 A16芯片排名靠后,M1系列霸榜(苹果自研芯片跑分对比)
热门推荐
- 织梦首页如何设置指定栏目(详解织梦模板DEDECMS搜索结果调用自定义字段的方法)
- 云服务器实例一直在停止(云服务器重启原因有哪些?)
- apache协议内容(Apache中rewrite伪静态规则介绍)
- mysqlsql语句的优化(MySQL优化之如何写出高质量sql语句)
- serv-u界面怎么设置中文(Serv-U 550 Permission denied 的解决办法)
- python继承重写构造函数(Python子类继承父类构造函数详解)
- sql对象资源管理在哪(SQL 尚未定义空闲 CPU 条件 - OnIdle 作业计划将不起任何作用)
- ftp文件管理工具(ftp服务器PDF文件在线查看的实现方法)
- python的遍历循环(对python For 循环的三种遍历方式解析)
- setTimeout和setIntelval的用法和区别