本文讲解如何在 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创作工具
相关推荐
Betelgeuse761 小时前
Django 中间件 4 大钩子 & CBV vs FBV 对比实战草莓熊Lotso1 小时前
【Linux网络】UDP Socket 编程全解析:从回显服务到通用字典服务,从零实现工业级代码92year8 小时前
用Google ADK从零搭一个能调工具的AI Agent:Python实操全过程woxihuan1234568 小时前
SQL删除数据时存在依赖关系_设置外键级联删除ON DELETE东风破1378 小时前
DM8达梦共享存储集群DSC搭建步骤雪碧聊技术8 小时前
当数据库字段数大于Java实体类属性数时,MyBatis还能映射成功吗?一文详解Jetev9 小时前
如何确定SQL字段是否为空_使用IS NULL与IS NOT NULL蛐蛐蛐9 小时前
昇腾910B4上安装新版本CANN的正确流程m0_702036539 小时前
mysql如何处理不走索引的OR查询_使用UNION ALL优化重写代钦塔拉9 小时前
Qt4 vs Qt5 带参数信号槽的连接方式详解