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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章