thinkphp5 递归查询所有子代,查询上级,并且获取层级

function get_childs( $parent_id = array(), $level = 0 ){
 
    static  $id_arr = array(); 
    $id_arr= Db::name('users')->where('parent_id','in',$parent_id)->column('id');
    
     //限制3级
    if (!empty($id_arr)&& $level<3) {
        $level++;
        $id_arr=array_merge($id_arr,get_childs($id_arr,$level));
    }
    return $id_arr;
}

    public  function getParent( $pid ,$array=[]) {

        static $level = 1;
        $is_parent = Db::name( 'Users')->where(["id"=>$pid])->find();

        $array[] = $is_parent;
        if ( $is_parent["reid"] ) {
            $level++;
            return $this->getParent( $is_parent['reid'],$array);
        }

        
        return $array;

    }
    //调用
        $userInfo = Db::name('Users')->where('id',10)->find(); 

        if ($userInfo['reid']>0) {
            $this->getParent($userInfo['reid']);
        }

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值