部门列表找每一个部门下的所有员工数,循环调用递归出现重复数组的问题

WBOY
发布: 2016-08-18 09:15:51
原创
1098 人浏览过

问题:
代码如下:

<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
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!