【PHP】查询用户的直推、非直推、二级、三级、团队人数示例

目录

1.构建公共函数,命名为team

2.使用方法,以yii2为例


首先在你的user表需要有一个字段串联推荐关系,如:

  • 我的id是666
  • 上级关系字段是superior
  • 字段值是:333_222_111 或 333,222,111

1.构建公共函数,命名为team


php 复制代码
<?php
/**
 * @author zzoood
 */
namespace common\querys;
class UserQuery extends BaseQuery
{
    public function team($uid, $level = 1, $column = 'superior') {
        if ($level == 1) {//直推
            $this->andWhere("$column REGEXP '^{$uid}_'");
        } elseif ($level == 2) {//非直推
            $this->andWhere("$column REGEXP '_{$uid}_'");
        } elseif ($level == 3) {//团队(直推 + 非直推)
            $this->andWhere("$column REGEXP '^{$uid}_|_{$uid}_'");
        } elseif ($level == 12) {//二级
            $this->andWhere("$column REGEXP '^[0-9]+_{$uid}_'");
        } elseif ($level == 13) {//三级
            $this->andWhere("$column REGEXP '^[0-9]+_[0-9]+_{$uid}_'");
        }
        return $this;
    }
}

参数说明:

  • $uid:用户ID,用于匹配团队关系中的上级或下级。

  • $level:整数型参数,默认为1,表示要查找的团队层级。不同的值对应不同的层级关系:

    • 1:直推,即直接推荐的下级,其superior字段以 $uid 开头并跟随下划线。
    • 2:非直推,即不是直接推荐但存在间接推荐关系,其superior字段中包含 $uid 并且 $uid 前后均有其他数字和下划线。
    • 3:团队,包括直推及所有间接推荐的下级,其superior字段以 $uid 开头或在任意两个数字之间包含 $uid
    • 12:二级,表示与 $uid 直接间隔一级的下级,其superior字段以至少一个数字开头,然后是 $uid,之后再跟一个下划线。
    • 13:三级,表示与 $uid 直接间隔两级的下级,其superior字段以至少两个数字开头,每个数字间用下划线分隔,最后是 $uid
  • $column:字符串类型,默认为 'superior',表示用于存储上下级关系的字段名。

在函数内部,根据传入的 $level 参数使用正则表达式来设置查询条件,并将其添加到当前查询对象中。最后返回当前查询对象以便进行链式调用,进一步完成查询过程。

2.使用方法,以yii2为例


php 复制代码
$teamMembers = User::find()->team(111, 2)->all();

这条语句会查询出与用户ID为111有间接推荐关系(非直推)的所有团队成员记录。

相关推荐
Shi_haoliu8 小时前
SolidTime 在 Rocky Linux 9.5 上的完整部署流程
linux·运维·nginx·postgresql·vue·php·laravel
成工小白14 小时前
网络复习(1)
服务器·网络·php
恃宠而骄的佩奇15 小时前
蚁剑 php一句话木马简单免杀(编码)绕过360,火绒
开发语言·web安全·php·免杀·一句话木马·火绒安全
m0_7381207216 小时前
渗透测试——y0usef靶机渗透提权详细过程(插件伪造请求头)
服务器·网络·web安全·ssh·php
qq_4061761418 小时前
JS防抖与节流:从原理到实战的性能优化方案
服务器·数据库·php
独行soc18 小时前
2026年渗透测试面试题总结-1(题目+回答)
android·开发语言·网络·安全·web安全·渗透测试·php
IT瑞先生18 小时前
php unicode与中文互转
android·开发语言·php
这儿有一堆花19 小时前
服务器安全:防火墙深度配置指南
服务器·安全·php
这儿有一堆花19 小时前
Linux 内网环境构建与配置深度解析
linux·数据库·php
2501_9419820521 小时前
企业微信外部群消息推送的“工程化”方案
开发语言·mysql·php