首頁 > 後端開發 > php教程 > 部門列表找每個部門下的所有員工數,循環呼叫遞歸出現重複數組的問題

部門列表找每個部門下的所有員工數,循環呼叫遞歸出現重複數組的問題

WBOY
發布: 2016-08-18 09:15:51
原創
1141 人瀏覽過

問題:
程式碼如下:

<code>  //查找所有下级部门的id
    public static function actionSon($company_id,$id)
    {   
        global $temp;
        $modelClass = self::find()
            ->where(['parent_id'=>$id,'company_id'=>$company_id]) 
            ->all();  
        if(!empty($modelClass)){
            foreach ($modelClass as $k => $value) { 
                $temp[] =$value->id;
                self::actionSon($company_id,$value->id);//调用函数,传入参数,继续查询下级
            }
        }
        return $temp;
    }
    </code>
登入後複製
登入後複製
<code>fields里面调用
    public function fields()
    {
        return [
            'id',
            'company_id'
            'user_count'=>function(){

                // return $this->getUserCount();
                $dep_ids=self::actionSon($this->company_id,$this->id);  
                // $GLOBALS['temp']=[];
               //unset($temp);
print_r($dep_ids);
              
            },
        ];
    }</code>
登入後複製
登入後複製

結果輸出:
部門列表找每個部門下的所有員工數,循環呼叫遞歸出現重複數組的問題

得出重複的數據,如果列表還有部門的話會這樣一直重複下去,如何解決這個問題?
我需要的結果是每調用一次就能獲取到當前部門下的所有子部門的id,以一維數組的形式展示。
把$GLOBALS['temp']=[];放開它只能找到一級。

回覆內容:

問題:
程式碼如下:

<code>  //查找所有下级部门的id
    public static function actionSon($company_id,$id)
    {   
        global $temp;
        $modelClass = self::find()
            ->where(['parent_id'=>$id,'company_id'=>$company_id]) 
            ->all();  
        if(!empty($modelClass)){
            foreach ($modelClass as $k => $value) { 
                $temp[] =$value->id;
                self::actionSon($company_id,$value->id);//调用函数,传入参数,继续查询下级
            }
        }
        return $temp;
    }
    </code>
登入後複製
登入後複製
<code>fields里面调用
    public function fields()
    {
        return [
            'id',
            'company_id'
            'user_count'=>function(){

                // return $this->getUserCount();
                $dep_ids=self::actionSon($this->company_id,$this->id);  
                // $GLOBALS['temp']=[];
               //unset($temp);
print_r($dep_ids);
              
            },
        ];
    }</code>
登入後複製
登入後複製

結果輸出:
部門列表找每個部門下的所有員工數,循環呼叫遞歸出現重複數組的問題

得出重複的數據,如果列表還有部門的話會這樣一直重複下去,如何解決這個問題?
我需要的結果是每調用一次就能獲取到當前部門下的所有子部門的id,以一維數組的形式展示。
把$GLOBALS['temp']=[];放開它只能找到一級。

相關標籤:
php
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板