Laravel 8.41 中的高效游标分页

发布时间 作者

Highly Performant Cursor Pagination in Laravel 8.41 image

Laravel 团队发布了 8.41 版本,其中包含游标分页、一种新的 Eloquent 方法用于静默更新模型、一种新的字符串方法以及 8.x 分支中的最新更改。

游标分页

Paras Malhotra 贡献了 游标分页 支持。Laravel 文档对游标分页与其他用于从数据库检索数据页面的分页方法之间的区别进行了很好的解释。

游标分页通过构建“where”子句来工作,这些子句比较查询中包含的有序列的值,从而在所有 Laravel 分页方法中提供最高效的数据库性能。这种分页方法特别适合大型数据集和“无限”滚动用户界面。

与基于偏移量的分页不同,基于偏移量的分页在分页器生成的 URL 的查询字符串中包含一个页面编号,基于游标的分页在查询字符串中放置一个“游标”字符串。

游标分页解决了在基于偏移量的分页中发现的重复问题,这些问题通常会影响无限滚动和 API 使用。游标分页在处理大型数据集时效率更高。

以下是一个快速示例,展示了它的外观。

$users = User::orderBy('id')->cursorPaginate(10);

给定上述用于十条记录的分页调用,以下是一个示例,说明如果我们在控制器中返回此实例,响应会是什么。

{
"data": [
{
"id": 1,
"name": "Nona Wilkinson",
"email": "[email protected]",
"email_verified_at": "2021-05-12T23:21:19.000000Z",
"created_at": "2021-05-12T23:21:19.000000Z",
"updated_at": "2021-05-12T23:21:19.000000Z"
},
{
"id": 2,
"name": "Titus Feeney Sr.",
"email": "[email protected]",
"email_verified_at": "2021-05-12T23:21:19.000000Z",
"created_at": "2021-05-12T23:21:19.000000Z",
"updated_at": "2021-05-12T23:21:19.000000Z"
},
{...}
],
"path": "http://127.0.0.1:8000/users",
"per_page": 10,
"next_page_url": "http://127.0.0.1:8000/users?cursor=eyJpZCI6MTAsIl9wb2ludHNUb05leHRJdGVtcyI6dHJ1ZX0",
"prev_page_url": null
}

如您所见,您不能依赖于用于基于偏移量的分页的 ?page=2 查询参数。您必须使用提供的 next_page_url 参数来获取下一页结果。

游标分页为 Laravel 框架和生态系统带来了巨大的益处 - 祝贺 Paras Malhotra 为此做出了如此出色的贡献(以及他所做的其他许多贡献)。

静默更新模型

GitHub 用户 @YTauber 贡献了一个 Eloquent 方法,用于更新模型而不会引发任何事件。

// `updateQuietly` works like `update()` but without raising events
 
$user->updateQuietly(['email' => '[email protected]']);

Str 替换方法

Selçuk Çukur 贡献了一个 Str::replace() 方法,用于与 StrStringable 类一起使用。

use Illuminate\Support\Str;
 
Str::replace('dead', 'alive', 'PHP is dead');
/* PHP is alive */
 
Str::of('PHP is dead')->replace('dead', 'alive');
/*
Illuminate\Support\Stringable {#4091
value: "PHP is alive",
}
*/

发行说明

您可以在下面查看新功能和更新的完整列表,以及 8.40.0 和 8.41.0 之间的差异。以下发行说明直接来自 变更日志

v8.41.0

新增

  • 新增 Illuminate\Database\Eloquent\Model::updateQuietly() (#37169)
  • 新增 Illuminate\Support\Str::replace() (#37186)
  • 在 whereKey() 和 whereKeyNot() 中添加模型密钥提取到 id (#37184)
  • 新增对 Pusher 6.x 的支持 (#37223, 819db15)
  • 新增 Illuminate/Foundation/Http/Kernel::getMiddlewarePriority() (#37271)
  • 新增游标分页(也称为键集分页)(#37216, #37315)
  • 支持对 SQL Server 视图进行批量赋值 (#37307)
  • 新增 Illuminate/Support/Stringable::unless() (#37326)

修复

  • 修复了 Illuminate\Database\Query\Builder::offset() 在非数字 $value 情况下的问题 (#37164)
  • 将失败的队列作业中缺失的 UUID 视为空字符串(失败驱动程序 = 数据库)(#37251)
  • 修复了在 required_unless 中未要求的字段 (#37262)
  • SqlServer 语法:hasTable 和 dropIfExists 的错误修复 / 支持在这些函数中使用模式名称 (#37280)
  • 修复了 Windows 上的 PostgreSQL 导出和导入 (#37320)

更改

  • 当迁移不是匿名类时添加回退 (#37166)
  • Ably 在 Illuminate\Broadcasting\Broadcasters\AblyBroadcaster::validAuthenticationResponse() 中期望 clientId 为字符串 (#37249)
  • 在获取排除的中间件之前计算控制器中间件 (#37259)
  • 更新 MIME 扩展名检查 (#37332)
  • 在无法确定最后一个 ID 时,将异常添加到 chunkById() (#37294)
Paul Redmond photo

Laravel 新闻的撰稿人。全栈 Web 开发人员和作者。

Cube

Laravel 新闻稿

加入 40,000 多名其他开发人员,不错过任何新技巧、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动补全和对本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

绝不妥协

Joel 和 Aaron,两位来自 No Compromises 播客的经验丰富的开发人员,现在可以为您的 Laravel 项目提供服务。 ⬧ 固定价格 7500 美元/月。 ⬧ 没有冗长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

绝不妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序成功。

Kirschbaum
Shift logo

Shift

运行旧版本的 Laravel?即时、自动化的 Laravel 升级和代码现代化,使您的应用程序保持新鲜感。

Shift
Bacancy logo

Bacancy

以每月 2500 美元的价格,为您的项目配备经验丰富的 Laravel 开发人员,拥有 4-6 年的经验。获得 160 小时的专用专业知识和 15 天的无风险试用期。立即安排电话咨询!

Bacancy
Lucky Media logo

Lucky Media

现在就选择 Lucky - Laravel 开发的理想选择,拥有十多年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 电子商务。一个开源软件包,将现代无头电子商务功能的强大功能引入 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 职位网站

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动套件

SaaSykit 是一个 Laravel SaaS 启动套件,包含运行现代 SaaS 所需的所有功能。支付、精美结账、管理面板、用户仪表板、身份验证、即用型组件、统计信息、博客、文档等。

SaaSykit:Laravel SaaS 启动套件
Rector logo

Rector

您的无缝 Laravel 升级合作伙伴,降低成本,加速创新,助力企业成功

Rector
MongoDB logo

MongoDB

通过 MongoDB 和 Laravel 的强大集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解灵活、现代的 MongoDB 数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的无依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包在 Laravel 应用程序中添加评论

阅读文章