首页 >后端开发 >PHP问题 > 正文

php如何高效找出所有下级

原创2019-10-29 15:01:3501984

PHP高效的取出所有下级:

递归取出所有下级:

<?php
 
$data = [
	[
		'uid' => 1,
		'username' => '155',
		'parent_username' => '0'
	],
	[
		'uid' => 2,
		'username' => '186',
		'parent_username' => '155'
	],
	[
		'uid' => 3,
		'username' => '189',
		'parent_username' => '186'
	],
	[
		'uid' => 4,
		'username' => '188',
		'parent_username' => '155'
	],
	[
		'uid' => 5,
		'username' => '187',
		'parent_username' => '188'
	],
	[
		'uid' => 6,
		'username' => '1898',
		'parent_username' => '146'
	],
];
 
/**
 * 获取所有下级
 * [getTree description]
 * @param  [type] $data            [description]
 * @param  string $parent_username [description]
 * @return [type]                  [description]
 */
//有层次,返回所有下级数据
function getTree($data, $parent_username = '0')
{
    $arr = [];
	foreach($data as $key => $val){
		if($val['parent_username'] == $parent_username){
			$val['children'] = getTree($data, $val['username']);
			$arr[] = $val;
		}
	}
	return $arr;
}
 
//无层次,仅返回id
function getTree($data, $parent_username = '0', $is_first_time = true)
{
    static $arr = [];
    if ($is_first_time) {
        $arr = [];
    }
    foreach ($data as $key => $val) {
        if ($val['parent_username'] == $parent_username) {
            $arr[]           = $val['uid'];
            getTree($data, $val['username'], false);
        }
    }
    return $arr;
}
 
echo '<pre>';
print_r(getTree($data));
 
 
 
?>

推荐:php服务器

以上就是php如何高效找出所有下级的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:php
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    推荐视频教程
  • PHP语法基础与数据库详解教程PHP语法基础与数据库详解教程
  • PHP经典算法面试题PHP经典算法面试题
  • ThinkPHP6.0极速入门(视频教程)ThinkPHP6.0极速入门(视频教程)
  • 视频教程分类