使用 MySQL 进行分页
admin
2024-03-17 23:41:26
0

拥有一个大型数据集并且只需要获取特定数量的行,这就是 LIMIT子句的存在原因。它允许限制 SQL 查询语句返回的结果中的行数。

分页是指将大型数据集划分为较小部分的过程。

通过一次获取小块数据来更快地向用户发送数据的能力是使用分页的好处之一。

工作原理

分页的工作原理是定义每个请求的结果中的最大行数以及所请求的页面。

下表表示名为users的表上的项目,该表将用作示例。

+----+----------+
| id | Name     |
+----+----------+
| 1  | John     |
| 2  | Jane     |
| 3  | Peter    |
| 4  | Joseph   |
| 5  | Mary     |
| 6  | Jack     |
| 7  | Ann      |
| 8  | Bill     |
| 9  | Sam      |
| 10 | Rose     |
| 11 | Juan     |
+----+----------+

对于此示例,最大行数将是2,这意味着在每个请求中,我们最多将获得 2 行。

该表有 11 行,我们将每个请求的结果限制为 2 行,导致 6 页 2 个项目。页数的确定方法是将行数 (11) 除以每页的行数 (2),并确保结果四舍五入到下一个整数。

Total pages = CEIL(Total number of rows / Limit number of rows)

MySQL没有PAGE子句,但它有OFFSET子句,它允许将位置从开始计数的位置移动到LIMIT数字。​​​​​​​​​​​​​​

OFFSET的值是通过将LIMIT子句值乘以您要查找的页码减去 1 来完成的。​​​​​​​

OFFSET = LIMIT * (PAGE - 1)

在上表中有 11 个用户,为了获取前 2 个用户,我们使用以下查询:

PAGE = 1
LIMIT = 2
OFFSET = (PAGE-1) * LIMIT
OFFSET = (1-1) * 2
OFFSET = 0 * 2
OFFSET = 0

偏移量初始值是0,而不是​​​​​​​1,这就是我们从页码中减去 1 的原因。

SELECT `id`, `name`
FROM `users`
LIMIT 2
OFFSET 0

前面的查询将生成以下结果,表示分页的第 1 页:

+----+----------+
| id | Name     |
+----+----------+
| 1  | John     |
| 2  | Jane     |
+----+----------+

MySQL有不同的方法来使用偏移量,而不使用OFFSET子句。

SELECT `id`, `name`
FROM `users`
LIMIT 0,2

第一个参数是偏移量,第二个参数是行计数。

要获得第二页,或者换句话说,接下来的两行,我们必须再次计算理论上增加一个OFFSET值。

PAGE = 2
LIMIT = 2
OFFSET = (PAGE-1) * LIMIT
OFFSET = (2-1) * 2
OFFSET = 1 * 2
OFFSET = 2

SELECT `id`, `name`
FROM `users`
LIMIT 2
OFFSET 2

下面可以看到上一个查询的结果:

+----+----------+
| id | Name     |
+----+----------+
| 3  | Peter    |
| 4  | Joseph   |
+----+----------+

查询将转换为跳过前 2 项并获取接下来的 2 行。

因此,在第三页中,我们使用以下 OFFSET 4 项来跳过前 4 项。

PAGE = 3
LIMIT = 2
OFFSET = (PAGE-1) * LIMIT
OFFSET = (3-1) * 2
OFFSET = 2 * 2
OFFSET = 4

SELECT `id`, `name`
FROM `users`
LIMIT 2 OFFSET 4
+----+----------+
| id | Name     |
+----+----------+
| 5  | Mary     |
| 6  | Jack     |
+----+----------+

偏移和排序方式

有时同时使用OFFSET和ORDER BY可以使分页不起作用,以随机顺序返回行,并在每个页面上返回意外行。​​​​​​​

如果多行在 ORDER BY 列中具有相同的值,则服务器可以自由地以任意顺序返回这些行,并且可能会根据整体执行计划以不同的方式返回这些行。换句话说,这些行的排序顺序对于无序列是不确定的。MySQL 文档

最常见的情况是,如果您按没有索引的列排序,MySQL Server无法确定行的正确顺序。

解决此问题的一种方法是向一个或多个列添加索引。尽管如果您不想或不需要仅为此目的向多个列添加索引,这可能不是最佳选择。

如果确保具有和不带 LIMIT 的行顺序相同很重要,请在 ORDER BY 子句中包含其他列以使顺序具有确定性。MySQL 文档

这意味着还有另一种解决此问题的方法是在ORDER BY子句中添加唯一列,例如主键列。

SELECT `id`, `name`
FROM `users`
LIMIT 2
OFFSET 2
ORDER BY `name`, `id`

而不是:

SELECT `id`, `name`
FROM `users`
LIMIT 2
OFFSET 2
ORDER BY `name`

这样,您可以确保MySQL在查找LIMIT行数之前按唯一列对行进行排序。

相关内容

热门资讯

邮储银行行长芦苇兼任公司首席合... 5月26日,邮储银行发布董事会决议公告,邮储银行行长芦苇自2026年5月26日起兼任邮储银行首席合规...
我愿意二次到店吗?小店主理人交... 来源:滚动播报 (来源:上观新闻) 咖啡店主理人可以去餐饮店体验一天,感受烟火气和客流管理;手工...
原创 深... 当政策暖风遇上资产配置需求,深圳楼市正上演一场“热度与信心齐飞”的戏码!上周(5.18-5.24),...
被封千万网红大蓝卷土重来:拉人... 蓝鲸新闻5月26日讯(记者 赵凯)“朋友圈散布经济恐慌言论制造焦虑,拉人头设多级返利,数百人入局、累...
抖音商城618前六日数据:消费... “清凉经济”热度高:抖音商城618首阶段空气循环扇订单量同比增长348% 作者 I 钱游 报道 I ...
金华有闲置贵金属想变现该怎么挑... 当下闲置物品处置、短期资金周转的需求日渐普遍,市面上的相关服务机构水平参差不齐,不少有黄金回收需求的...
千亿市值芯片企业完成IPO辅导... 【大河财立方消息】5月26日,新三板挂牌企业宸芯科技股份有限公司(证券简称:宸芯科技)公告,收到青岛...
NBBOSS R1全球首发 重... 5月26日,信人智能旗下全球首款企业家专属AI决策伙伴NBBOSS AI决策机器人R1正式全球首发。...
NFC果汁配料表“水”排第一?... 随着气温升高,果汁进入消费旺季。然而很多果汁产品的标注却让消费者感到困惑。比如:有的标注“纯果汁”,...
存储牛市与全民狂热:韩国股市泡... 2026年5月的韩国,正经历一场史无前例的资本狂欢。自2025年4月触底以来,KOSPI指数在18个...
下架,召回!双汇子公司猪肉抗生... 近日,黑龙江省市场监督管理局网站发布关于食品安全监督抽检信息的通告(2026年第7期)。 其中,望奎...
换帅潮席卷白酒圈 白酒本轮人事变动频次之高、画像之多元,几乎超过了过去任何一个周期。 5月19日,“河北王”老白干酒宣...
4月意大利起泡酒猛增122.5... 近日,海关总署公布了2026年4月葡萄酒进口数据。其中,起泡酒表现尤为突出,进口量同比增长35.8%...
华为“韬定律”提振港股半导体股... 财联社5月26日讯(编辑 胡家荣)半导体产业链个股集体走强。截至发稿,华虹半导体(01347.HK)...
历史不会重演,但会惊人相似:中... 金价疯涨别乱买!复刻2015年走势,普通人记住3个保命妙招 最近逛商场,最大的感受就是黄金柜台太热闹...
商品标签被指涉嫌性暗示,盒马道... 近日,盒马旗下一款粉木耳产品因标签设计引发争议,不少网友吐槽该商品标签低俗,涉嫌性暗示。 25日晚...
东莞一上市公司董事会“换血”,... 近日,易事特集团股份有限公司发布《关于董事会完成换届选举及聘任高级管理人员、证券事务代表暨公司控制权...
做宠物食品,已经很难赚到钱了? 流量争夺战里没有赢家 撰文/ 黎炫岐 编辑/ 李觐麟 排版/ Annalee “它经济”,一个持续升...
2万亿美元!SpaceX上市前... “你想在早上醒来时觉得未来会很美好——而这正是成为太空文明的全部意义所在。它关乎相信未来,并认为未来...