前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySql根据当前页pageNo、显示条数pageSize,实现分页查询的SQL

MySql根据当前页pageNo、显示条数pageSize,实现分页查询的SQL

作者头像
chenchenchen
发布2019-09-25 15:38:32
3.7K0
发布2019-09-25 15:38:32
举报
文章被收录于专栏:chenchenchenchenchenchen

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_38004638/article/details/101176465

一:分页需求:

客户端通过传递start(页码),limit(每页显示的条数)两个参数去分页查询数据库表中的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的需求不一样,所以就需要我们根据实际情况去改写适合我们自己的分页语句,具体的分析如下:

比如:

查询第1条到第10条的数据的sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据:select * from table limit (1-1)*10,10;

查询第10条到第20条的数据的sql是:select * from table limit 10,20; ->对应我们的需求就是查询第二页的数据:select * from table limit (2-1)*10,10;

查询第20条到第30条的数据的sql是:select * from table limit 20,30; ->对应我们的需求就是查询第三页的数据:select * from table limit (3-1)*10,10;

二:通过上面的分析,可以得出符合我们自己需求的分页sql格式

mysql分页:select * from 表 limit (pageNo-1)*pageSize,pageSize;

oracle分页:select a.* (select 表.*,rowum rn from 表) a where rn>(pageNo-1)*pageSize and rn <=pageNo*pageSize;

三、

代码语言:javascript
复制
在MyBatis中LIMIT之后的语句不允许的变量不允许进行算数运算,会报错。
代码语言:javascript
复制
    LIMIT (#{pageNo}-1)*#{pageSize},#{pageSize};  // 错误
代码语言:javascript
复制
    LIMIT ${(pageNo-1)*pageSize},${pageSize}; (正确)

四、使用分页工具类

代码语言:javascript
复制
mybatisplus分页工具类 IPage

分页查询优化:https://www.jianshu.com/p/7d1b6db64a8f

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年09月22日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档