php 無(wú)限級(jí)分類 獲取頂級(jí)分類ID
有這樣一個(gè)表,id是分類的ID,name是分類名稱,pid是上級(jí)分類的ID。
現(xiàn)在有個(gè)分類ID,程序要找到它上級(jí)的上級(jí)的上級(jí)……分類的ID,簡(jiǎn)單說(shuō)就是找出頂級(jí)分類的ID。
比如“新鮮水果”的ID是13,對(duì)應(yīng)父類ID是5,而5的父ID是1,1沒(méi)有父類,也就是頂級(jí)分類了。
以前年輕氣盛不懂事,總想著用遞歸來(lái)查找,然后再將結(jié)果緩存來(lái)解決性能問(wèn)題。
后來(lái)又試過(guò)將整個(gè)表緩存起來(lái),再遞歸查找。
再后來(lái)……似乎比較少有機(jī)會(huì)遇到無(wú)限級(jí)分類……
最近有個(gè)同事問(wèn)我怎么“優(yōu)雅”的解決這個(gè)問(wèn)題。
于是我靈機(jī)一動(dòng),就有了如下解決方案:
<?php $sql = "select id, pid from tablename "; // 查詢后 將結(jié)果處理成 如下數(shù)組格式 $arr = [ // id => pid 1 => 0, // 省略... 5 => 1, // 省略... 13 => 5 ]; // 建議將這數(shù)組緩存起來(lái) $id = 13; while($arr[$id]) { $id = $arr[$id]; } echo $id; // 1
不得不說(shuō):真是太優(yōu)雅了!連我都佩服我自己了,同事更是五體投地,痛哭流涕。
因?yàn)樗麑?xiě)了幾十行循環(huán)再判斷再遞歸的代碼,被我用兩行代碼替換了……
相關(guān)文章
PHP實(shí)現(xiàn)本地圖片轉(zhuǎn)base64格式并上傳
這篇文章主要介紹了PHP實(shí)現(xiàn)本地圖片轉(zhuǎn)base64格式并上傳,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05php警告Creating default object from empty value 問(wèn)題的解決方法
PHP 提示 Creating default object from empty value 的問(wèn)題,一般是由于PHP版升級(jí)的原因,PHP 5.4 以上的版本一般會(huì)報(bào)這個(gè)錯(cuò)誤2014-04-04PHP使用strstr()函數(shù)獲取指定字符串后所有字符的方法
這篇文章主要介紹了PHP使用strstr()函數(shù)獲取指定字符串后所有字符的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了PHP中strstr()函數(shù)用于字符串截取的使用技巧,需要的朋友可以參考下2016-01-01PHP 獲取文件路徑(靈活應(yīng)用__FILE__)
__FILE__ ,是返回文件的完整路徑和文件名。如果用在包含文件中,則返回包含文件名。自 PHP 4.0.2 起,__FILE__ 總是包含一個(gè)絕對(duì)路徑,而在此之前的版本有時(shí)會(huì)包含一個(gè)相對(duì)路徑2013-02-02php中時(shí)間函數(shù)date及常用的時(shí)間計(jì)算
本篇文章主要介紹了php中時(shí)間函數(shù)date及常用的時(shí)間計(jì)算的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-05-05PHP編程獲取各個(gè)時(shí)間段具體時(shí)間的方法
這篇文章主要介紹了PHP編程獲取各個(gè)時(shí)間段具體時(shí)間的方法,結(jié)合實(shí)例形式分析了基于date與strtotime函數(shù)進(jìn)行日期時(shí)間運(yùn)算的相關(guān)操作技巧,需要的朋友可以參考下2017-05-05學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)工廠模式(factory)
這篇文章主要介紹了php設(shè)計(jì)模式中的工廠模式,使用php實(shí)現(xiàn)工廠模式,感興趣的小伙伴們可以參考一下2015-12-12