php遞歸如何獲取無(wú)限上級(jí)ID
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 '用戶(hù)名', `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)
| id | pid | name |
|---|---|---|
| 1 | 0 | 汽車(chē) |
| 2 | 1 | 歐拉 |
| 3 | 1 | 吉利 |
| 4 | 3 | 沃爾沃 |
| 5 | 1 | 大眾 |
代碼
/**
* 遞歸實(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即時(shí)捕捉PHP中的錯(cuò)誤并發(fā)送email通知的實(shí)現(xiàn)代碼
這段代碼,其用意就是當(dāng)我們寫(xiě)的php程式出錯(cuò)的時(shí)候把錯(cuò)誤內(nèi)容捕捉出來(lái)然后發(fā)到我們的email內(nèi),方便我們排錯(cuò)2013-01-01
PHP zlib擴(kuò)展實(shí)現(xiàn)頁(yè)面GZIP壓縮輸出
GZIP(GNU-ZIP)是一種壓縮技術(shù)。經(jīng)過(guò)GZIP壓縮后頁(yè)面大小可以變?yōu)樵瓉?lái)的30%甚至更小。這樣用戶(hù)瀏覽的時(shí)候就會(huì)感覺(jué)很爽很愉快!2010-06-06
PHP判斷訪客是否手機(jī)端(移動(dòng)端瀏覽器)訪問(wèn)的方法總結(jié)【4種方法】
這篇文章主要介紹了PHP判斷訪客是否手機(jī)端(移動(dòng)端瀏覽器)訪問(wèn)的方法,結(jié)合實(shí)例形式總結(jié)分析了php基于HTTP_X_WAP_PROFILE、HTTP_VIA、HTTP_USER_AGENT、HTTP_ACCEPT等4種方法判斷訪客類(lèi)型的相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
簡(jiǎn)單了解WordPress開(kāi)發(fā)中update_option()函數(shù)的用法
這篇文章主要介紹了WordPress開(kāi)發(fā)中update_option()函數(shù)的用法,update_option()函數(shù)經(jīng)常被用于更新數(shù)據(jù)庫(kù)中的數(shù)據(jù),需要的朋友可以參考下2016-01-01
PHP實(shí)現(xiàn)將顏色hex值轉(zhuǎn)換成rgb的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)將顏色hex值轉(zhuǎn)換成rgb的方法,涉及PHP針對(duì)字符串與數(shù)組的數(shù)學(xué)運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2016-05-05
PHP設(shè)計(jì)模式之裝飾器模式定義與用法簡(jiǎn)單示例
這篇文章主要介紹了PHP設(shè)計(jì)模式之裝飾器模式定義與用法,結(jié)合簡(jiǎn)單實(shí)例形式分析了php裝飾器模式的概念、原理、定義與簡(jiǎn)單使用方法,需要的朋友可以參考下2018-08-08

