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

本文详解如何在 Laravel 中避免在 Blade 模板中嵌套循环与字符串解析,转而使用数据库层的 FIND_IN_SET 原生查询精准筛选含指定分类 ID 的记录,并配合 limit() 实现高性能、可预测的前 N 条结果输出。 本文详解如何在 laravel 中避免在 blade 模板中嵌套循环与字符串解析,转而使用数据库层的 `find_in_set` 原生查询精准筛选含指定分类 id 的记录,并配合 `limit()` 实现高性能、可预测的前 n 条结果输出。在实际开发中,当数据表字段(如 cat)以逗号分隔字符串形式存储多个分类 ID(例如 '3,4'、'1,4'),直接在 Blade 模板中用 explode() + 多层 @foreach 进行匹配不仅逻辑臃肿、性能低下,更会导致无法真正实现"取前 5 条匹配结果"------因为 ->take(5) 作用于原始数据集,而非筛选后的子集。您当前的输出仅显示 2 条,正是因为前 5 条原始记录中仅有 2 条包含 '4'。? 正确解法是:将筛选逻辑下推至数据库层,利用 MySQL 内置函数 FIND_IN_SET() 高效完成匹配,并通过 limit() 精确控制最终返回条数。? 推荐方案:使用 whereRaw('FIND_IN_SET(?, cat)')修改您的控制器方法如下:// app/Http/Controllers/Frontend/CategoryController.phppublic function CAT(){ cat_select = '4'; // 可动态传入,如 request()-\>input('cat') cats = DB::table('blog') ->whereRaw("FIND_IN_SET(?, cat)", [$cat_select]) ->orderBy('id', 'DESC') ->limit(5) ->get(); return view('frontend.category', compact('cats'));}对应 Blade 模板简化为: 橙篇 百度文库发布的一款综合性AI创作工具

相关推荐
a7963lin1 小时前
PHP怎么实现单例模式_PHP常用设计模式之单例模式【方法】
jvm·数据库·python
Aision_4 小时前
从工具调用到 MCP、Skill完整学习记录
java·python·gpt·学习·langchain·prompt·agi
辞旧 lekkk8 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
2301_809204709 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy2777710 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
Aaswk10 小时前
Java Lambda 表达式与流处理
java·开发语言·python
笨蛋不要掉眼泪10 小时前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite10 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋911 小时前
ruoyi项目更换为mysql9.7.0数据库
数据库
Andya_net11 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql