php查找顶级分类,php 无限级分类 获取顶级分类ID,php顶级_PHP教程
php 無(wú)限級(jí)分類 獲取頂級(jí)分類ID,php頂級(jí)
有這樣一個(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),就有了如下解決方案:
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)再判斷再遞歸的代碼,被我用兩行代碼替換了……
您可能感興趣的文章:php+mysql實(shí)現(xiàn)無(wú)限級(jí)分類 | 樹(shù)型顯示分類關(guān)系
php實(shí)現(xiàn)無(wú)限級(jí)分類實(shí)現(xiàn)代碼(遞歸方法)
php 無(wú)限級(jí)分類,超級(jí)簡(jiǎn)單的無(wú)限級(jí)分類,支持輸出樹(shù)狀圖
ThinkPHP無(wú)限級(jí)分類原理實(shí)現(xiàn)留言與回復(fù)功能實(shí)例
php實(shí)現(xiàn)無(wú)限級(jí)分類
PHP實(shí)現(xiàn)遞歸無(wú)限級(jí)分類
PHP實(shí)現(xiàn)無(wú)限級(jí)分類(不使用遞歸)
http://www.bkjia.com/PHPjc/1109173.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/1109173.htmlTechArticlephp 無(wú)限級(jí)分類 獲取頂級(jí)分類ID,php頂級(jí) 有這樣一個(gè)表,id是分類的ID,name是分類名稱,pid是上級(jí)分類的ID。 現(xiàn)在有個(gè)分類ID,程序要找到它...
總結(jié)
以上是生活随笔為你收集整理的php查找顶级分类,php 无限级分类 获取顶级分类ID,php顶级_PHP教程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 浦发信用卡分期手续费怎么算 分期与一次性
- 下一篇: 银行开始大洗牌,一大批银行将消失,又一家