当前位置:首页 > PHP > 正文内容

php无限查询下级,php递归统计下级总数,php 获取无限子级

高老师8年前 (2017-10-11)PHP8503

因项目需要需要统计用户无限下级计算分销佣金,计算每月分红,计算无限下级团队的业绩,需要先获得某个会员的无限下级成员。先看看数据库中的member表字段

id            username              agentid(上级id)

1               张三                         0

2               李四                         1

3               李四                         2

4               王五                         3

5               马六                         4

.......................

1.递归模式(因为PHP在递归方面限制层级厉害,无限下级不建议采用)

private  $members;//保存二级分享所有团队人员
/*
 * 计算某个用户无限下级.
 * 返回的数据并不包含用户自身.
 * $mid为某用户的id
 */
public  function  GetTeamMember($mid){
	$Tempmerbers=pdo_fetchall("select id,openid from ". tablename('ewei_shop_member')." where agentid=".$mid);//查询id为mid的用户的直接下级
	$this->members=array_merge($this->members,$Tempmerbers);//查询结果保存到私有属性members中
	if(count($Tempmerbers)>0){//再将上面查询到的直接下级递归查询下级
		foreach ($Tempmerbers as $value) {
			$this->GetTeamMember($value['id']);
		}
	}		
}

2.非递归模式

//1.整个会员表的数据
$member = array(
	array('id'=>1, 'agentid'=>0, 'nickname' => 'A'), 
	array('id'=>2, 'agentid'=>1, 'nickname' => 'B'),
	array('id'=>3, 'agentid'=>1, 'nickname' => 'C'),
	array('id'=>4, 'agentid'=>8, 'nickname' => 'D'),
	array('id'=>5, 'agentid'=>3, 'nickname' => 'E'),
	array('id'=>6, 'agentid'=>3, 'nickname' => 'F'),
	array('id'=>7, 'agentid'=>3, 'nickname' => 'G'),
	array('id'=>8, 'agentid'=>8, 'nickname' => 'H')
);

/*
*2.获取某个会员的无限下级方法
*$members是所有会员数据表,$mid是用户的id
*/
function GetTeamMember($members, $mid) {
	$Teams=array();//最终结果
	$mids=array($mid);//第一次执行时候的用户id
	do {
		$othermids=array(); 
		$state=false;
		foreach ($mids as $valueone) {
			foreach ($members as $key => $valuetwo) {
				if($valuetwo['agentid']==$valueone){
					$Teams[]=$valuetwo['id'];//找到我的下级立即添加到最终结果中
					$othermids[]=$valuetwo['id'];//将我的下级id保存起来用来下轮循环他的下级
					array_splice($members,$key,1);//从所有会员中删除他
					$state=true;	
				}
			}			
		}
		$mids=$othermids;//foreach中找到的我的下级集合,用来下次循环
	} while ($state==true);

	return $Teams;
}

$res=GetTeamMember($member ,1);

var_dump($res);

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/43.html

分享给朋友:

“php无限查询下级,php递归统计下级总数,php 获取无限子级” 的相关文章

php生成验证码

php生成验证码

<?php //高先生简单验证码. //随机数 //为什么循环0-15的数字 //因为要实现最简单的字母和数字混搭 //16进制0-9   a-f //dechex 十进制转换为16进制 //创建一个四位的验证码. //$nmsg.  ...

 php max input vars,max input vars限制,max input vars 设置

php max input vars,max input vars限制,max input vars 设置

在一个正式项目中操作人员提交239个产品信息进行保存,但是系统却提示没有提交239个产品,于是开启错误信息,显示如下:Warning: Unknown: Input variables exceeded 1000. To incr...

PHP二维数组排序,PHP多维数组排序, array_multisort()

PHP二维数组排序,PHP多维数组排序, array_multisort()

使用php函数array_multisort()即可实现和SQL一样的order by排序. 例如我们需要对会员表按照主键降序排列,年龄升序排列://会员表数据 $list = []; $list[] = ['mid' =>&n...

PHP Startup: Unable to load dynamic library 'C:\php\ext\php_curl.dll找不到指定的模块

PHP Startup: Unable to load dynamic library 'C:\php\ext\php_curl.dll找不到指定的模块

最近在编写windows php多线程的东西,从官网下载了PHP的线程安全版,尝试开启curl扩展extension=php_curl.dllphp -m 却提示 PHP Startup: Unable to load dynamic library 'C:\php\ext\php_curl...

 php命令行中文乱码,php cli中文乱码

php命令行中文乱码,php cli中文乱码

<?php //如果支持exec函数,可以使用的方式 exec('chcp 65001'); //如果exec函数因安全问题禁用,可以使用的方式 pclose(popen('chcp 65001', 'r'));...

 thinkphp5定时任务,tp5定时任务,thinkphp定时任务,php定时任务,php定时器

thinkphp5定时任务,tp5定时任务,thinkphp定时任务,php定时任务,php定时器

本教程使用的定时任务基于EasyTak,EasyTask官方文档:https://gitee.com/392223903/EasyTask(1).安装tp5.0或者5.1composer create-project topthink/think=5.0.* tp5&n...