Laravel Blade 中高效筛选并限制关联分类数据的实践指南

本文讲解如何在 Laravel 中避免在 Blade 模板中嵌套循环与字符串解析,转而使用数据库层的 WHERE FIND_IN_SET() 配合 limit() 实现精准、高效的数据筛选与分页控制。 本文讲解如何在 laravel 中避免在 blade 模板中嵌套循环与字符串解析,转而使用数据库层的 `where find_in_set()` 配合 `limit()` 实现精准、高效的数据筛选与分页控制。在 Laravel 开发中,当数据表字段以逗号分隔(如 cat = '3,4')存储多个分类 ID 时,若直接在 Blade 模板中用 explode() + 嵌套 @foreach 进行匹配和截断,不仅逻辑冗余、可读性差,更会导致全表遍历+PHP 层过滤,严重损害性能与可维护性------尤其当数据量增长后,cats-\>take(5) 仅作用于原始查询结果,无法保证其中恰好包含 5 条满足 cat_select = '4' 的记录。? 正确做法是:将筛选逻辑下沉至数据库层,利用 MySQL 原生函数 FIND_IN_SET() 精准定位含指定值的记录,并结合 limit() 严格控制返回条数。? 推荐解决方案(控制器层优化)修改 CategoryController@CAT 方法,使用 whereRaw() 调用 FIND_IN_SET():public function CAT(){ cat_select = '4'; // ? 数据库层筛选:查找 cat 字段中包含 '4' 的记录,且最多取 5 条 cats = DB::table('blog') -\>whereRaw("FIND_IN_SET(?, cat)", \[cat_select]) ->orderBy('id', 'DESC') // 按 ID 降序,确保最新匹配项优先 ->limit(5) ->get(); return view('frontend.category', 'cats' =\> $cats, 'cat_select' =\> $cat_select, );}? Blade 模板极简渲染此时模板无需任何 PHP 逻辑处理,直接遍历即可: 橙篇 百度文库发布的一款综合性AI创作工具

相关推荐
兵慌码乱5 小时前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析
python·sqlite·信号与槽·pyqt5·数据库设计·桌面应用开发·事务处理
金銀銅鐵7 小时前
[Python] 体验用欧几里得算法计算最大公约数的过程
python·数学
FreakStudio10 小时前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
用户03321266636712 小时前
使用 Python 从零创建 Word 文档
python
Csvn16 小时前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
曲幽17 小时前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了
python·docker·web·pot·translate·libretranslate·arogstranslate
用户5569188175319 小时前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维
倔强的石头_21 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
兵慌码乱1 天前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei1 天前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python