因项目需要需要统计用户无限下级计算分销佣金,计算每月分红,计算无限下级团队的业绩,需要先获得某个会员的无限下级成员。先看看数据库中的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); 首先下载wkhtmltox-0.12.4_linux-generic-amd64.tar.xz (不要下载RPM包,依赖太多,需要x-server支持),并解压,执行测试运行正常tar wkhtmltox-0.12.4_linux-generic-amd64.tar.xzcd...
php arrayaccess 官方的说法是让你能以数组的形式访问对象,对于这种php内置接口一直不太明白有什么用,坚持多看文章,终于理解,特来分享,思路不同,更易于理解。(1).创建一个学生类,并且实现arrayaccess 接口。<?php class studen...
上篇文章已经讲解arrayacces的原理,现在来讲解下arrayaccess的实际应用。一个大型的互联网项目中必然会存在各种配置信息,例如多种数据库信息:mysql,tidb,mongodb,redis,某个业务模块单独的配置信息如比例,额度等等,那么该如何治理配置信息?PHP项目中大部分的框架都...
为什么使用队列?因为pop取队列具有原子性。假如我们需要秒杀一个商品id,我们先将商品的库存保存到一个队列。例如:<?php $redis = new Redis(); $redis->connect('127.0.0.1', 6...
(1).管道是干嘛的?管道是用于进程之间通信的,传播或交换信息(2).管道有几种?(2.1).匿名管道(pipe):管道是一种半双工的通信方式,数据只能单向流动,而且只能在具有亲缘关系的进程间使用。通常是指父子进程关系。(2.2).高级管道(popen):将另一个程序当做一个新的进程在当前程序进程中...
本教程使用的定时任务基于EasyTak,EasyTask官方文档:https://gitee.com/392223903/EasyTask由于tp3.2.x官方开发未考虑命令行支持和绝对路径开发的标准,因此我编写了一个支持的类来运行。1.在tp3.2.3根目录下安装easytaskcomposer&...