欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php遞歸如何獲取無(wú)限上級(jí)ID

 更新時(shí)間:2022年09月06日 17:15:43   作者:何憂非喜{傲嬌的程序媛}  
這篇文章主要介紹了php遞歸如何獲取無(wú)限上級(jí)ID,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

php遞歸獲取無(wú)限上級(jí)ID

數(shù)據(jù)庫(kù)結(jié)構(gòu)

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 '昵稱(chēng)',
  `phone` varchar(20) DEFAULT NULL COMMENT '電話',
  `weixin_id` varchar(20) DEFAULT NULL COMMENT '微信號(hào)',
  `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是上級(jí)ID,無(wú)限分級(jí)

遞歸代碼

注意:在引用遞歸函數(shù)本身的時(shí)候,一定要return $this->遞歸函數(shù),否則返回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;
        }
    }

控制器調(diào)用

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

php無(wú)限極分類(lèi)(遞歸)

建表的時(shí)候,增加一個(gè)PID字段用來(lái)區(qū)別自己所屬的分類(lèi)

idpidname
10汽車(chē)
21歐拉
31吉利
43沃爾沃
51大眾

代碼

/**
     * 遞歸實(shí)現(xiàn)無(wú)限極分類(lèi)
     * @param $array 分類(lèi)數(shù)據(jù)
     * @param $pid 父ID
     * @param $level 分類(lèi)級(jí)別
     * @return $list 分好類(lèi)的數(shù)組 直接遍歷即可 $level可以用來(lái)遍歷縮進(jìn)
     */
function getTree($array, $pid =0, $level = 0){
        //聲明靜態(tài)數(shù)組,避免遞歸調(diào)用時(shí),多次聲明導(dǎo)致數(shù)組覆蓋
        static $list = [];
        foreach ($array as $key => $value){
            //第一次遍歷,找到父節(jié)點(diǎn)為根節(jié)點(diǎn)的節(jié)點(diǎn) 也就是pid=0的節(jié)點(diǎn)
            if ($value['pid'] == $pid){
                //父節(jié)點(diǎn)為根節(jié)點(diǎn)的節(jié)點(diǎn),級(jí)別為0,也就是第一級(jí)
                $value['level'] = $level;
                //把數(shù)組放到list中
                $list[] = $value;
                //把這個(gè)節(jié)點(diǎn)從數(shù)組中移除,減少后續(xù)遞歸消耗
                unset($array[$key]);
                //開(kāi)始遞歸,查找父ID為該節(jié)點(diǎn)ID的節(jié)點(diǎn),級(jí)別則為原級(jí)別+1
                getTree($array, $value['id'], $level+1);
            }
        }
        return $list;
    }
    /*
     * 獲得遞歸完的數(shù)據(jù),遍歷生成分類(lèi)
     */
    $array = getTree($array);
    foreach($array) as $value{
       echo str_repeat('--', $value['level']), $value['name'].'<br />';
    }
//輸出結(jié)果 無(wú)限極分類(lèi)實(shí)現(xiàn)ok
/**
河北省
--邯鄲市
----永年區(qū)
--武安市
北京市
--朝陽(yáng)區(qū)
----望京
----酒仙橋
--通州區(qū)
**/

PHP null轉(zhuǎn)成空字符串

		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;

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • php生成隨機(jī)密碼的三種方法小結(jié)

    php生成隨機(jī)密碼的三種方法小結(jié)

    使用PHP開(kāi)發(fā)應(yīng)用程序,尤其是網(wǎng)站程序,常常需要生成隨機(jī)密碼,如用戶注冊(cè)生成隨機(jī)密碼,用戶重置密碼也需要生成一個(gè)隨機(jī)的密碼。
    2010-09-09
  • PHP數(shù)組操作類(lèi)實(shí)例

    PHP數(shù)組操作類(lèi)實(shí)例

    這篇文章主要介紹了PHP數(shù)組操作類(lèi),涉及php針對(duì)數(shù)組的刪除、轉(zhuǎn)換、分組、排序等相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • PHP中全面阻止SQL注入式攻擊分析小結(jié)

    PHP中全面阻止SQL注入式攻擊分析小結(jié)

    PHP是一種力量強(qiáng)大但相當(dāng)容易學(xué)習(xí)的服務(wù)器端腳本語(yǔ)言,即使是經(jīng)驗(yàn)不多的程序員也能夠使用它來(lái)創(chuàng)建復(fù)雜的動(dòng)態(tài)的web站點(diǎn)。然而,它在實(shí)現(xiàn)因特網(wǎng)服務(wù)的秘密和安全方面卻常常存在許多困難
    2012-01-01
  • 生成ubuntu自動(dòng)切換壁紙xml文件的php代碼

    生成ubuntu自動(dòng)切換壁紙xml文件的php代碼

    運(yùn)行代碼后在圖片目錄下會(huì)生成yuxing.xml,方便ubuntu自動(dòng)切換壁紙.
    2010-07-07
  • Yii使用queue實(shí)現(xiàn)隊(duì)列流程講解

    Yii使用queue實(shí)現(xiàn)隊(duì)列流程講解

    Yii是一個(gè)高性能的PHP5的web應(yīng)用程序開(kāi)發(fā)框架。通過(guò)一個(gè)簡(jiǎn)單的命令行工具yiic可以快速創(chuàng)建一個(gè)web應(yīng)用程序的代碼框架,開(kāi)發(fā)者可以在生成的代碼框架基礎(chǔ)上添加業(yè)務(wù)邏輯,以快速完成應(yīng)用程序的開(kāi)發(fā)
    2022-11-11
  • Redis構(gòu)建分布式鎖

    Redis構(gòu)建分布式鎖

    本文主要介紹了Redis構(gòu)建分布式鎖的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-03-03
  • 10個(gè)php函數(shù)實(shí)用卻不常見(jiàn)

    10個(gè)php函數(shù)實(shí)用卻不常見(jiàn)

    函數(shù)是PHP如此強(qiáng)大的源泉,但是很多PHP函數(shù)并沒(méi)有得到充分的利用。這里,我們給大家簡(jiǎn)單介紹10個(gè)不常見(jiàn),但非常有用的函數(shù)。
    2015-10-10
  • ThinkPHP中處理表單中的注意事項(xiàng)

    ThinkPHP中處理表單中的注意事項(xiàng)

    這篇文章主要介紹了ThinkPHP中處理表單中的注意事項(xiàng),分析并總結(jié)了ThinkPHP表單處理中需要注意的問(wèn)題,包括URL訪問(wèn)、錯(cuò)誤處理、查詢、添加、刪除的技巧等問(wèn)題,需要的朋友可以參考下
    2014-11-11
  • php面向?qū)ο蟪绦蛟O(shè)計(jì)介紹

    php面向?qū)ο蟪绦蛟O(shè)計(jì)介紹

    在面向?qū)ο蟮某绦蛟O(shè)計(jì)(英語(yǔ):Object-oriented programming,縮寫(xiě):OOP)中,對(duì)象是一個(gè)由信息及對(duì)信息進(jìn)行處理的描述所組成的整體,是對(duì)現(xiàn)實(shí)世界的抽象
    2023-04-04
  • PHP同時(shí)連接多個(gè)mysql數(shù)據(jù)庫(kù)示例代碼

    PHP同時(shí)連接多個(gè)mysql數(shù)據(jù)庫(kù)示例代碼

    這篇文章主要介紹了PHP同時(shí)連接多個(gè)mysql數(shù)據(jù)庫(kù)的具體實(shí)現(xiàn),需要的朋友可以參考下
    2014-03-03

最新評(píng)論