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']);
        }

 

发布了57 篇原创文章 · 获赞 16 · 访问量 9万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览