php 無限級分類 獲取頂級分類ID
有這樣一個表,id是分類的ID,name是分類名稱,pid是上級分類的ID。
現(xiàn)在有個分類ID,程序要找到它上級的上級的上級……分類的ID,簡單說就是找出頂級分類的ID。
比如“新鮮水果”的ID是13,對應(yīng)父類ID是5,而5的父ID是1,1沒有父類,也就是頂級分類了。
以前年輕氣盛不懂事,總想著用遞歸來查找,然后再將結(jié)果緩存來解決性能問題。
后來又試過將整個表緩存起來,再遞歸查找。
再后來……似乎比較少有機會遇到無限級分類……
最近有個同事問我怎么“優(yōu)雅”的解決這個問題。
于是我靈機一動,就有了如下解決方案:
<?php
$sql = "select id, pid from tablename ";
// 查詢后 將結(jié)果處理成 如下數(shù)組格式
$arr = [
// id => pid
1 => 0,
// 省略...
5 => 1,
// 省略...
13 => 5
];
// 建議將這數(shù)組緩存起來
$id = 13;
while($arr[$id]) {
$id = $arr[$id];
}
echo $id; // 1
不得不說:真是太優(yōu)雅了!連我都佩服我自己了,同事更是五體投地,痛哭流涕。
因為他寫了幾十行循環(huán)再判斷再遞歸的代碼,被我用兩行代碼替換了……
相關(guān)文章
《Head First 設(shè)計模式》代碼之PHP版(面向?qū)ο髮W習)
《Head First 設(shè)計模式》是本不錯的講解設(shè)計模式的書,不像F4寫的那么枯燥,應(yīng)該算是比較容易理解的好書。2010-06-06
php采用curl模仿登錄人人網(wǎng)發(fā)布動態(tài)的方法
這篇文章主要介紹了php采用curl模仿登錄人人網(wǎng)發(fā)布動態(tài)的方法,分析了curl登陸人人網(wǎng)的原理與具體方法,非常具有實用價值,需要的朋友可以參考下2014-11-11
PHP入門教程之字符串處理技巧總結(jié)(轉(zhuǎn)換,過濾,解析,查找,截取,替換等)
這篇文章主要介紹了PHP入門教程之字符串處理技巧,結(jié)合實例形式總結(jié)分析了php針對字符串的刪除空格、特殊字符轉(zhuǎn)換、過濾、解析、分割、查找、截取、替換、獲取、判斷、計算等操作技巧,需要的朋友可以參考下2016-09-09

