Laravel 查询构建器

发布日期 作者

Laravel Query Builder image

Laravel 查询构建器是 Alex Vanderbist 和 Spatie 团队开发的一个包,用于快速从 API 请求构建 Eloquent 查询。这个包使创建复杂的 Laravel API 查询变得非常简单。虽然您可能已经听说过这个包(或者使用过它),但我希望确保每个人都了解它!

我强烈建议您试用 Query Builder 并阅读 README 文件,了解它的功能。它使创建 API 过滤器和其他与查询相关的任务变得如此容易,您可能会觉得自己在作弊。

您可以执行的一些基本示例包括:过滤 API 请求,包含相关模型,将其与现有查询结合使用,对 API 请求进行排序。

例如,使用请求 /users?filter[name]=John,您可以像这样在 users 表的 name 字段上使用过滤功能

use Spatie\QueryBuilder\QueryBuilder;
 
// ...
 
$users = QueryBuilder::for(User::class)
->allowedFilters('name')
->get();
// all `User`s that contain the string "John" in their name

如果您有现有查询,可以将其传递给查询构建器

$query = User::where('active', true);
 
$user = QueryBuilder::for($query)
->allowedIncludes('posts', 'permissions')
->where('score', '>', 42) // chain on any of Laravel's query builder methods
->first();

一个更高级的示例,也是我个人最喜欢的功能之一,就是范围过滤器。假设您有以下范围

public function scopeStartsBefore(Builder $query, $date): Builder
{
return $query->where('starts_at', '>=', Carbon::parse($date));
}

关联的查询构建器可能看起来像这样

QueryBuilder::for(Event::class)
->allowedFilters([
Filter::scope('starts_before'),
])
->get();

使用上面的查询构建器,现在可以像这样执行以下查询来根据 starts_before 列过滤结果

GET /events?filter[starts_before]=2018-01-01

了解更多

您可以在 GitHub 上查看源代码并阅读有关如何安装和使用此包的文档,地址为 spatie/laravel-query-builder。本文中的示例来自 Laravel Query Builder README 文件,我建议您阅读整个文件以获取更多详细信息。

您可以在 Laravel 5 项目中使用以下 Composer 命令安装此包

composer require spatie/laravel-query-builder
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 是来自“无妥协”播客的两位经验丰富的开发者,他们现在可以为您的 Laravel 项目提供服务。 ⬧ 固定费率为 7,500 美元/月。 ⬧ 无需冗长的销售流程。 ⬧ 无需合同。 ⬧ 100% 退款保证。

无妥协
Kirschbaum logo

Kirschbaum

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

Kirschbaum
Shift logo

Shift

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

Shift
Bacancy logo

Bacancy

使用经验丰富的 Laravel 开发人员(拥有 4-6 年经验)为您的项目提供强大助力,每月只需 2,500 美元。获得 160 小时的专业服务和 15 天无风险试用。立即安排通话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - 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

将 Swagger UI 添加到您的 Laravel 应用程序

阅读文章
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 提示构建 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 应用程序添加评论

阅读文章