Laravel条件查询构造器使用方法
时间:2026-05-13 18:42:49 335浏览 收藏
Laravel 的条件查询构造器为开发者提供了灵活、安全且可维护的动态数据库查询能力,涵盖 when/ unless 动态分支控制、where 数组批量筛选、whereRaw 原生 SQL 精确介入、以及本地作用域封装复用等五大核心技巧——无论你是应对复杂搜索过滤、多场景权限判断,还是追求代码简洁性与SQL安全性,这套机制都能帮你告别冗长 if-else 拼接和硬编码 SQL,写出更优雅、健壮且易于扩展的查询逻辑。

如果您在使用 Laravel 的 Eloquent ORM 或 Query Builder 进行数据库操作时,需要根据动态条件构建 SQL 查询,则需借助其灵活的条件查询构造器机制。以下是实现条件查询构造器的多种方法:
一、使用 when 方法动态添加查询条件
when 方法允许您仅在给定条件为 true 时才执行闭包中的查询链式调用,避免手动拼接 if-else 判断,使代码更简洁可读。
1、定义基础查询实例,例如 User::query()。
2、调用 when($condition, function ($query) { ... }),其中 $condition 为布尔表达式或变量。
3、在闭包中调用 where()、orderBy() 等方法添加条件。
4、最终调用 get() 或 first() 执行查询。
二、使用 where 条件数组批量应用筛选
当多个字段需同时按值精确匹配时,可直接传入关联数组给 where(),Laravel 自动将其转换为 AND 连接的等值条件。
1、准备一个键值对数组,如 ['status' => 'active', 'deleted_at' => null]。
2、将该数组作为第二个参数传入 where('users', $conditions)。
3、确保数组中键名为数据库字段名,值为期望匹配的值。
4、执行 get() 获取结果集。
三、使用 whereRaw 手动编写原生条件表达式
当需要使用数据库特有函数(如 MySQL 的 DATE()、LIKE 模糊匹配带通配符)、或复杂逻辑运算(如 IS NULL、BETWEEN)时,whereRaw() 提供了直接嵌入 SQL 片段的能力。
1、调用 whereRaw('created_at >= ?', [$date]),使用问号占位符防止 SQL 注入。
2、若需绑定多个参数,传入数组形式的第二个参数,如 ['2023-01-01', '2023-12-31']。
3、可在同一查询中多次调用 whereRaw() 与其他 where 方法混合使用。
4、注意确保 SQL 片段语法与所用数据库引擎兼容。
四、使用 when 和 unless 组合处理双向条件分支
unless 是 when 的逻辑反向方法,当条件为 false 时才执行闭包;两者配合可用于实现“满足 A 则查 X,否则查 Y”的分支逻辑。
1、初始化查询对象,如 Post::query()。
2、先调用 when($isPublished, function ($q) { return $q->where('published', true); })。
3、再调用 unless($isPublished, function ($q) { return $q->where('draft', true); })。
4、最后统一调用 paginate(15) 返回分页结果。
五、使用作用域(Local Scopes)封装复用条件逻辑
将常用条件组合抽象为模型上的本地作用域方法,可在任意查询中通过链式调用复用,提升可维护性与一致性。
1、在 Eloquent 模型类中定义以 scope 开头的公共方法,如 scopeActive($query)。
2、方法内部对传入的 $query 调用 where('status', 'active') 并返回 $query。
3、在控制器或服务中使用 User::active()->get() 触发该作用域。
4、支持接收参数的作用域命名为 scopeOfType($query, $type),调用时为 ->ofType('admin')。
以上就是《Laravel条件查询构造器使用方法》的详细内容,更多关于的资料请关注golang学习网公众号!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
401 收藏
-
484 收藏
-
110 收藏
-
287 收藏
-
442 收藏
-
439 收藏
-
255 收藏
-
145 收藏
-
335 收藏
-
470 收藏
-
287 收藏
-
305 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习