使用MySQL的递延Join连接实现高效分页 - Aaron

使用MySQL的递延Join连接实现高效分页 - Aaron,第1张

在 Web 应用程序中跨大型数据集分页记录似乎是一个简单的问题,但实际上很难扩展。两种主要的分页策略是偏移/限制和游标

我们将首先看一下这两种方法,然后稍作修改,可以使偏移/限制非常高效。

偏移/限制分页

偏移/限制方法是迄今为止最常见的方法,它通过跳过一定数量的记录(页)并将结果限制为一页来工作。

例如,假设您的应用程序配置为每页显示 15 条记录。您的 SQL 将如下所示:

这是最常见的,因为它非常简单,易于推理,并且几乎每个框架都支持它。

除了易于实现之外,它还具有页面可直接寻址的优点。例如,如果您想直接导航到第 20 页,您可以这样做,因为该偏移量很容易计算。

但是有一个主要的缺点,它潜伏在数据库处理偏移量的方式中。偏移量告诉数据库放弃从查询中返回的前N个结果。不过数据库仍然要从磁盘上获取这些行。

如果你丢弃的是100条记录,这并不重要,但如果你丢弃的是100,000条记录,数据库就会为了丢弃这些结果而做大量的工作。

在实践中,这意味着第一个页面会快速加载,之后的每一个页面都会变得越来越慢,直到你达到一个点,网络请求可能会直接超时。

基于游标的分页

基于游标的分页弥补了偏移/限制的一些不足,同时引入了一些自己的不足。

基于游标的分页是通过存储一些关于最后呈现给用户的记录的状态,然后根据这个状态来进行下一次查询。

因此,它不是按顺序获取所有的记录并丢弃前N条,而是只获取最后一个位置N之后的记录。

如果按ID排序,SQL可能看起来像这样。

你可能已经看到了其中的好处。因为我们知道上次向用户展示的ID,我们知道下一个页面将以一个更高的ID开始。我们甚至不需要检查ID较低的行,因为我们百分之百肯定地知道那些行不需要被显示。

在上面的例子中,我特别说明了ID可能不是连续的,也就是说,可能有缺失的记录。这使得我们无法计算出哪些记录会出现在某一页面上,你必须跟踪之前那一页面上的最后一条记录是什么。

与偏移/限制分页不同,使用游标分页时,页面不能直接寻址,你只能导航到 "下一页 "或 "上一页"。

不过光标分页的好处是在任何数量的页面上都很迅速。它也很适合无限滚动,在这种情况下,页面首先不需要可以直接寻址。

Laravel文档中有一些关于偏移量和游标之间的权衡的好的背景。

>

语句顺序

select 选择的列

from 表

where 查询的条件

group by 分组属性 having 分组过滤的条件

order by 排序属性

limit 起始记录位置,取记录的条数

其中

select 选择的列

from 表

where 查询的条件

以上是基本的结构

group by 分组属性 having 分组过滤的条件

这个是按照分组属性进行分组,所有分组属性上值相同的记录被分为一组,作为结果中的一条记录,后面的having是对分组进行过滤的条件,必须和group by一起使用

order by 排序属性 是对结果集合进行排序,可以是升序asc,也可以是降序desc

limit 起始记录位置,取记录的条数

对记录进行选取,主要用来实现分页功能

以上就是关于使用MySQL的递延Join连接实现高效分页 - Aaron全部的内容,包括:使用MySQL的递延Join连接实现高效分页 - Aaron、mysql为什么group by不能显示全部数据、mysql中的select语句where条件group by ,having , order by,limit的顺序及用法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9716034.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存