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

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

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

因项目需要需要统计用户无限下级计算分销佣金,计算每月分红,计算无限下级团队的业绩,需要先获得某个会员的无限下级成员。先看看数据库中的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验证码不显示的问题应该是经常的事情,我在这里把2种解决方案都发出来方便大家后期使用.因为是昨天晚上自己写验证码都没有显示,我就直接把之前和李炎恢老师上课写的验证码拿来还是不显示,醉了。首先是第一种方法:1、打开服务器安装目录下的php.ini文件;2、去掉;extension=php_gd.d...

PHP获取原始数据

PHP获取原始数据

在项目中需要对图片进行裁剪,前端裁剪完成发送base64给后端,但是很意外的PHP获取到的数据和前端有点差距,之前我都是先加密,后端解密,但是这次依然不行。于是使用filter_input方法轻松解决。$base64 =  filter_input(INPUT_POST...

Thinkphp Call Stack,PHP调用栈Call Stack的获取

Thinkphp Call Stack,PHP调用栈Call Stack的获取

ThinkPHP中有一个debug调试功能,能输出报错文件的信息,并能看到这个函数被哪些函数调用,从框架的启动开始记录,特别方便调试。于是研究了下它的底层给予了实现。<?php //--框架核心--Start //框架内置错误处理 function errDealWith($er...

全方位认识PHP的SESSION

全方位认识PHP的SESSION

【一】.介绍session由于HTTP是无状态的请求,创建一个会话需要保持必须需要身份标识。当用户第一次访问,PHP会为用户创建一个唯一的sessionid,并将sessionid通过cookie发送给浏览器,并在服务器的临时文件创建一个以sessionid为名的文件用来保存这个sessionid保...

php多进程实现任务管理器,定时执行任务,支持守护

php多进程实现任务管理器,定时执行任务,支持守护

主要原理是通过PHP创建多个子进程,在子进程中发送进程闹钟信号,然后再监听闹钟信号中继续发送闹钟信号。同时通过父进程设置非阻塞运行。代码如下:<?php /**  * 订单任务  */ class Order {    &n...

posix_ttyname函数详解

posix_ttyname函数详解

posix_ttyname - 获取当前终端设备名称。<?php     var_dump( posix_ttyname(STDOUT) );我们启动一个终端,执行上面的代码输出:/dev/tty1我们再启动一个终端,执行上面的代码输...