返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >php递归如何获取无限上级ID
  • 587
分享到

php递归如何获取无限上级ID

2024-04-02 19:04:59 587人浏览 泡泡鱼
摘要

目录PHP递归获取无限上级ID数据库结构递归代码控制器调用php无限极分类(递归)PHP null转成空字符串php递归获取无限上级ID 数据库结构 CREATE TABLE `fc

php递归获取无限上级ID

数据库结构

CREATE TABLE `fcxlt_authuser` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(50) NOT NULL COMMENT '用户名',
  `passWord` varchar(64) NOT NULL COMMENT '密码',
  `nickname` varchar(50) NOT NULL COMMENT '昵称',
  `phone` varchar(20) DEFAULT NULL COMMENT '电话',
  `weixin_id` varchar(20) DEFAULT NULL COMMENT '微信号',
  `qrcode` varchar(200) DEFAULT NULL COMMENT '二维码Base64',
  `auth_id` int(11) NOT NULL,
  `is_authed` int(11) NOT NULL,
  `createtime` int(11) NOT NULL DEFAULT '1523156898',
  PRIMARY KEY (`id`),
  KEY `nickname` (`nickname`),
  KEY `auth_id` (`auth_id`,`id`,`username`,`nickname`) USING BTREE,
  KEY `username` (`username`,`is_authed`,`password`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=103 DEFAULT CHARSET=utf8mb4

其中auth_id是上级ID,无限分级

递归代码

注意:在引用递归函数本身的时候,一定要return $this->递归函数,否则返回NULL

public function getWinfo($id,$res=''){
        if($id>1){
            $infos = Db::name('authuser')
                ->alias('a')
                ->where('a.id',$id)
                ->join('fcxlt_authuser b', 'a.auth_id=b.id', 'LEFT')
                ->field('a.auth_id as id')
                ->find();
//        dump($infos);
            if(!empty($infos) && $infos['id']>1){
                $res.= $infos['id'].",";
                return $this->getWinfo($infos['id'],$res);
            }else{
                return $res;
            }
        }else{
            return $res;
        }
    }

控制器调用

$ids = $this->getWinfo($id,$res=$id.',');
$id_in =  substr($ids,0,strlen($ids)-1);
$id_arr = explode(',',$id_in);

php无限极分类(递归)

建表的时候,增加一个PID字段用来区别自己所属的分类

idpidname
10汽车
21欧拉
31吉利
43沃尔沃
51大众

代码


function getTree($array, $pid =0, $level = 0){
        //声明静态数组,避免递归调用时,多次声明导致数组覆盖
        static $list = [];
        foreach ($array as $key => $value){
            //第一次遍历,找到父节点为根节点的节点 也就是pid=0的节点
            if ($value['pid'] == $pid){
                //父节点为根节点的节点,级别为0,也就是第一级
                $value['level'] = $level;
                //把数组放到list中
                $list[] = $value;
                //把这个节点从数组中移除,减少后续递归消耗
                unset($array[$key]);
                //开始递归,查找父ID为该节点ID的节点,级别则为原级别+1
                getTree($array, $value['id'], $level+1);
            }
        }
        return $list;
    }
    
    $array = getTree($array);
    foreach($array) as $value{
       echo str_repeat('--', $value['level']), $value['name'].'<br />';
    }
//输出结果 无限极分类实现ok

PHP null转成空字符串

		public function convertNullToEmptyString($data) {
	        $data = collect($data)->map(function ($value){
	            if (is_null($value)) {
	                return '';
	            }
	            return is_array($value) ? $this->convertNullToEmptyString($value) : $value;
	        });
	        return $data->toArray();
	    }
		$data = array(
            [
                'name' => 'shawn',
                'email' => 'shw@qq.com',
                'company' => 'aa'
            ],
            [
                'name' => '111',
                'email' => 'ssdfas@dasf',
                'company' => 'ssdfa'
            ]
        );
        var_dump($this->convertNullToEmptyString($data));
        die;

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: php递归如何获取无限上级ID

本文链接: https://lsjlt.com/news/166992.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • php递归如何获取无限上级ID
    目录php递归获取无限上级ID数据库结构递归代码控制器调用php无限极分类(递归)PHP null转成空字符串php递归获取无限上级ID 数据库结构 CREATE TABLE `fc...
    99+
    2024-04-02
  • 怎么使用php递归实现无限级分类
    使用PHP递归实现无限级分类的步骤如下:1. 创建一个数组或从数据库中获取分类数据,包含id和parent_id字段,表示分类的唯一...
    99+
    2023-09-29
    php
  • php如何获取本页面的id
    在PHP中,可以使用$_SERVER['PHP_SELF']来获取当前页面的URL,然后使用parse_url函数解析URL,获取其...
    99+
    2023-10-22
    php
  • php无法获取请求如何解决
    这篇文章主要介绍“php无法获取请求如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“php无法获取请求如何解决”文章能帮助大家解决问题。确定请求的类型在PHP中,有多种不同类型的请求。最常见的...
    99+
    2023-07-05
  • 如何用php获取快手无水印视频
    这篇文章主要讲解了“如何用php获取快手无水印视频”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用php获取快手无水印视频”吧!这里说的解析无水印视频是通过调用第三方接口来完成的,这个第...
    99+
    2023-06-04
  • 如何用php获取抖音无水印视频
    这篇文章主要讲解了“如何用php获取抖音无水印视频”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何用php获取抖音无水印视频”吧!接口特点:Videoparse解析接口支持:抖音、快手、小...
    99+
    2023-06-04
  • 如何用PHP获取无水印西瓜视频
    本篇内容介绍了“如何用PHP获取无水印西瓜视频”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!这里说的解析获取西瓜无水印视频是通过调用第三方接...
    99+
    2023-06-04
  • 织梦DeDeCMS在列表与内容页中如何获取顶级栏目ID
    这篇文章将为大家详细讲解有关织梦DeDeCMS在列表与内容页中如何获取顶级栏目ID,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 织梦DeDeCMS在模板(列表与内容页...
    99+
    2024-04-02
  • web开发在列表与内容页中如何获取顶级栏目ID
    这篇文章将为大家详细讲解有关web开发在列表与内容页中如何获取顶级栏目ID,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 某个栏目标要做banner或别的的,只成份材上...
    99+
    2024-04-02
  • 如何用PHP获取最新抖音无水印视频
    这篇文章主要介绍“如何用PHP获取最新抖音无水印视频”,在日常操作中,相信很多人在如何用PHP获取最新抖音无水印视频问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用PHP获取最新抖音无水印视频”的疑惑有所...
    99+
    2023-06-04
  • 如何在IIS上安装SSL证书并解决PHP无法获取数据的问题
    在IIS上安装SSL证书并解决PHP无法获取数据的问题 在网站开发中,使用SSL证书来保障数据传输的安全是非常重要的。而在Windows平台上,IIS(Internet Informa...
    99+
    2024-03-09
    php iis ssl证书
  • IIS安装SSL证书后PHP无法获取数据如何解决
    这篇文章主要介绍“IIS安装SSL证书后PHP无法获取数据如何解决”,在日常操作中,相信很多人在IIS安装SSL证书后PHP无法获取数据如何解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”IIS安装SSL证...
    99+
    2023-07-05
  • 如何编写批处理bat命令获取当前盘符和当前目录和上级目录的代码
    这篇文章主要讲解了“如何编写批处理bat命令获取当前盘符和当前目录和上级目录的代码”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何编写批处理bat命令获取当前盘符和当前目录和上级目录的代码...
    99+
    2023-06-08
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作