Laravel中when和unless条件查询子句怎么用

when在条件为真时添加查询,unless在条件为假时添加查询,两者结合第三个参数可处理else逻辑,使Laravel查询更简洁清晰。

laravel中when和unless条件查询子句怎么用

在 Laravel 的查询构建器中,whenunless 是两个非常实用的条件控制方法,用于根据运行时条件动态添加查询逻辑,避免写一堆 if 判断,让%ignore_a_1%码更简洁清晰。

when:满足条件时执行查询

当你希望在某个值存在或满足条件时才添加查询语句,可以使用 when 方法。

语法如下:

$query->when($condition, function ($query) { … })

只有当 $condition 为 true(或可调用函数返回 true)时,闭包中的查询才会被应用。

示例:根据用户输入的搜索关键词过滤数据

$keyword = request(‘keyword’);

User::query()->when($keyword, function ($query) use ($keyword) {$query->where(‘name’, ‘like’, “%{$keyword}%”);})->get();

如果 $keyword 不为空,就会加上模糊查询;为空则跳过这个条件。

你也可以传入一个回调作为判断条件:

->when(auth()->check(), function ($query) { $query->where(‘is_active’, 1);})

unless:不满足条件时执行查询

unless 正好和 when 相反:只有当条件为 false 时,才会执行闭包中的查询。

STORYD STORYD

帮你写出让领导满意的精美文稿

STORYD 137 查看详情 STORYD

语法类似:

$query->unless($condition, function ($query) { … })

示例:仅当用户未提供状态筛选时,默认排除已删除记录

$status = request(‘status’);

User::query()->unless($status, function ($query) {$query->where(‘deleted_at’, null);})->get();

也就是说,如果 $status 为空(即没选状态),就自动加个软删除过滤;如果已选择,则不加这个限制。

结合 else 场景使用 when 的第三个参数

when 还支持第三个参数,用来处理“否则”逻辑。

->when($condition, function ($query) { /* 条件为真时 */ }, function ($query) { /* 条件为假时 */ })

示例:管理员看全部数据,普通用户只能看自己的

User::query() ->when( auth()->user()->is_admin, function ($query) { // 管理员:不做限制 }, function ($query) { $query->where(‘id’, auth()->id()); } ) ->get();

基本上就这些。合理使用 whenunless 能让你的查询逻辑更干净,减少 if-else 嵌套,提升可读性。

以上就是Laravel中when和unless条件查询子句怎么用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/830727.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月27日 07:39:02
下一篇 2025年11月27日 09:33:21

相关推荐

  • Word2013如何插入SmartArt图形_Word2013SmartArt插入的视觉表达

    答案:可通过四种方法在Word 2013中插入SmartArt图形。一、使用“插入”选项卡中的“SmartArt”按钮,选择所需类型并插入;二、从快速样式库中选择常用模板如组织结构图直接应用;三、复制已有SmartArt图形到目标文档后调整内容与格式;四、将带项目符号的文本选中后右键转换为Smart…

    2025年12月6日 软件教程
    000
  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    000
  • word表格怎么调整行高_word表格行高调整的具体操作

    手动拖动可快速调整单行行高;2. 通过表格属性精确设置指定高度,选择固定值或最小值模式;3. 全选表格批量统一行高;4. 设为自动或最小值使行高随内容自适应,确保文字显示完整。 在使用Word制作表格时,调整行高是常见的排版需求。合理的行高能让表格内容更清晰易读。下面介绍几种常用的调整Word表格行…

    2025年12月6日 软件教程
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    000
  • Pboot插件数据库连接的配置教程_Pboot插件数据库备份的自动化脚本

    首先配置PbootCMS数据库连接参数,确保插件正常访问;接着创建auto_backup.php脚本实现备份功能;然后通过Windows任务计划程序或Linux Cron定时执行该脚本,完成自动化备份流程。 如果您正在开发或维护一个基于PbootCMS的网站,并希望实现插件对数据库的连接配置以及自动…

    2025年12月6日 软件教程
    000
  • Linux命令行中wc命令的实用技巧

    wc命令可统计文件的行数、单词数、字符数和字节数,常用-l统计行数,如wc -l /etc/passwd查看用户数量;结合grep可分析日志,如grep “error” logfile.txt | wc -l统计错误行数;-w统计单词数,-m统计字符数(含空格换行),-c统计…

    2025年12月6日 运维
    000
  • Linux密码策略如何配置_Linux密码策略配置的详细指南

    答案:Linux密码策略通过PAM模块和配置文件设置密码复杂度、有效期、重复使用限制及账户锁定规则,提升系统安全。具体包括:1. 配置pam_pwquality.so实现最小长度8位、含大小写字母、数字、特殊字符,允许输错3次;2. 修改/etc/login.defs设置密码最长使用90天、最短7天…

    2025年12月6日 运维
    000
  • 环境搭建docker环境下如何快速部署mysql集群

    使用Docker Compose部署MySQL主从集群,通过配置文件设置server-id和binlog,编写docker-compose.yml定义主从服务并组网,启动后创建复制用户并配置主从连接,最后验证数据同步是否正常。 在Docker环境下快速部署MySQL集群,关键在于合理使用Docker…

    2025年12月6日 数据库
    000
  • Laravel多态关联?多态关系怎样使用?

    多态关联解决了一个模型需关联多种父模型时的冗余问题,通过commentable_id和commentable_type字段实现灵活扩展,避免多外键带来的结构混乱与维护难题。 Laravel的多态关联,简单来说,就是让一个模型能够同时属于多个不同类型的模型。想象一下,你有一个评论(Comment)模型…

    2025年12月6日 PHP框架
    000
  • 解决MongoDB连接错误:正确使用MongoClient进行数据库连接

    本教程旨在解决初次使用mongodb时常见的“mongodb.connect is not a function”错误。我们将详细介绍如何使用mongodb官方驱动中的`mongoclient`类建立稳定的数据库连接,并结合express.js框架,采用现代化的`async/await`语法实现高效…

    2025年12月6日 web前端
    000
  • Laravel如何实现数据库Seeding_数据库初始数据填充

    Laravel数据库Seeding通过Seeder文件自动填充开发测试数据,结合Model Factories与Faker库可高效生成大量真实感数据,支持关联模型与状态定制,需注意外键约束顺序、幂等性处理、大批量数据性能优化及环境差异控制,确保数据一致性与可重复性。 Laravel的数据库Seedi…

    2025年12月6日 PHP框架
    000
  • Laravel如何保护路由需要登录访问_路由中间件与认证保护

    Laravel通过auth中间件结合认证系统实现路由保护,未登录用户访问受保护路由时被重定向至登录页。核心机制依赖会话管理:用户登录后ID存入会话并生成加密Cookie,后续请求由auth中间件验证会话中的用户信息。开发者可对单个路由、路由组或控制器应用middleware(‘auth&…

    2025年12月6日 PHP框架
    000
  • Laravel如何开启和关闭维护模式_站点维护状态切换

    Laravel维护模式通过php artisan down开启,php artisan up关闭,期间返回503状态码并显示自定义维护页面;可配合–secret、–refresh等参数优化体验,并需注意缓存、权限及CDN问题;部署时应集成维护命令以保障更新平稳。 Larave…

    2025年12月6日 PHP框架
    000
  • php查询代码怎么写_php数据库查询语句编写技巧与实例

    在PHP中进行数据库查询,最常用的方式是使用MySQLi或PDO扩展连接MySQL数据库。下面介绍基本的查询代码写法、编写技巧以及实用示例,帮助你高效安全地操作数据库。 1. 使用MySQLi进行查询(面向对象方式) 这是较为推荐的方式,适合大多数中小型项目。 // 创建连接$host = ‘loc…

    2025年12月6日 后端开发
    000
  • Laravel连接查询?连接查询怎样编写?

    Laravel连接查询的核心是通过外键关联多表数据,主要采用Eloquent ORM关系定义和查询构造器join方法。1. Eloquent通过模型定义hasMany、belongsTo等关系,使用with()预加载避免N+1查询问题,适合模型间有明确关联的场景;2. 查询构造器提供join、lef…

    2025年12月6日 PHP框架
    000
  • 解决ReactJS无法获取PHP JSON数据的问题:Axios集成指南

    本文旨在解决%ignore_a_1%js应用中无法从php后端正确获取json数据的问题。我们将探讨常见的`fetch` api使用场景及其可能遇到的挑战,并重点介绍如何通过集成`axios`库,实现稳定高效的跨域数据请求,确保php服务器返回的json数据能够被react组件成功消费和渲染。 在现…

    2025年12月6日 web前端
    000
  • Laravel计划任务?定时任务如何调度?

    Laravel计划任务通过单一cron入口点集中管理定时任务,所有调度逻辑定义在App\Console\Kernel.php的schedule方法中,使用链式调用如daily()、everyFiveMinutes()等设置频率,并支持Closure回调、Artisan命令和Shell命令调度。相比原…

    2025年12月6日 PHP框架
    000
  • Laravel Echo如何与Pusher配合使用_前端实时事件监听

    Laravel Echo与Pusher结合实现实时通信,后端通过配置广播驱动、创建可广播事件并触发,前端使用Echo订阅频道并监听事件。该组合优势在于与Laravel无缝集成、Pusher托管服务降低运维成本、支持私有频道认证授权,并具备自动重连机制,提升开发效率与系统稳定性。 Laravel Ec…

    2025年12月6日 PHP框架
    000
  • thinkphp数据库连接失败的常见原因和解决方法

    答案:ThinkPHP数据库连接失败常见原因包括配置错误、服务未启动、权限不足、扩展未安装及防火墙拦截。1. 检查database.php中hostname、username、password、database、hostport、charset配置是否正确;2. 确认MySQL服务已启动,可通过sy…

    2025年12月6日 PHP框架
    000
  • 解决 Laravel 模型方法从控制器调用时返回空数据的问题

    本文探讨了在 laravel 中从控制器调用模型方法时,数据返回为空的常见问题。核心原因在于未正确捕获模型方法返回的值。教程将通过示例代码演示如何正确调用模型方法并处理其返回值,同时强调模型与控制器职责分离的最佳实践,确保数据获取与响应生成流程的清晰与高效。 在 Laravel 应用开发中,模型(M…

    2025年12月6日
    000

发表回复

登录后才能评论
关注微信