获取某个分类的所有子孙分类id(不使用递归的一种实现技巧)

   /**
     * @param $cateid
     * 获取某个分类的所有子孙分类id(包括自身的id)
     */
    function getCateChilds($cateid){
        //获取所有记录
        $records=M("InformationsCate")->field('id,level,parent_id')->where(['status'=>1])->select();
        //获取最大等级
        $max_level=M("InformationsCate")->field('level')->where(['status'=>1])->order('level desc')->find()['level'];
        //获取当前分类的等级
        $my_level=M("InformationsCate")->where(['id'=>$cateid])->getField('level');
        //用于记录该分类的所有子分类,包括自身
        $my_child=[$cateid];
        //取出该分类的子分类ids
        for($i=$max_level;$i>$my_level;$i--){
            foreach($records as $key=>$val){
                if(in_array($val['parent_id'],$my_child)){
                    $my_child[]=$val['id'];unset($records[$key]);
                }
            }
        }
        return $my_child;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值