Laravel Eloquent关联模型查询(无限分类)设置查询条件与指定字段

  1. 模型
    下面展示一些 内联代码片
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class Cat extends Model
{

    protected $table = 'cat';
   
    public function child() {
        return $this->hasMany('App\Models\Cat', 'parent_id', 'id');
    }

    public function allChildren()
    {
        return $this->child()->with(['allChildren' => function($query) {
            $query->select('id', 'parent_id', 'name');
        }]);
    }
}

  1. 控制器调用
 $categories = cat::with(['allChildren' => function($query) {
            $query->select('id', 'parent_id', 'name');
        }])->select('id', 'parent_id', 'name')->get();
  1. 打印结果
{
           "id": 1,
           "name": "一级分类",
           "parent_id": 0,
           "all_children": [
               {
                   "id": 2,
                   "parent_id": 1,
                   "name": "二级分类1",
                   "all_children": []
               },
               {
                   "id": 3,
                   "parent_id": 1,
                   "name": "二级分类2",
                   "all_children": [
                   	{
                           "id": 4,
                           "parent_id": 3,
                           "name": "三级分类",
                           "all_children": []
                       }
               	]
               },
        	]
       },

https://blog.csdn.net/xiayu204575/article/details/106124948/

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值