本文详解如何在 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创作工具
相关推荐
数据库小学妹14 分钟前
MySQL ORDER BY 深度解析:Using temporary 与 Using filesort 的底层机制及索引优化实战唐装鼠25 分钟前
Nginx + Gunicorn + Python Web 应用 架构(Claude)梦想三三30 分钟前
【PYthon词频统计与文本向量化】苏宁易购评论分析实战AI人工智能+电脑小能手33 分钟前
【大白话说Java面试题 第93题】【Mysql篇】第23题:从查找速度来看,聚集索引和非聚集索引哪个更快?WPF工业上位机1 小时前
YXGK.FakeVM数据库示例牛奔1 小时前
如何让 GORM 打印 SQL 语句?三种方式全解析XWalnut1 小时前
Redis从入门到精通biter down1 小时前
9:JSONSchema日晨难再1 小时前
C语言&Python&Bash&Tcl:全局变量和局部变量麻雀飞吧1 小时前
期货量化主连和具体合约怎么切:天勤 KQ.m 与 KQ.i 用法