鍍金池/ 問答/PHP/ 如何用php獲取到某條數(shù)據(jù)的子分類、父分類、同級分類?

如何用php獲取到某條數(shù)據(jù)的子分類、父分類、同級分類?

比如數(shù)據(jù)庫結(jié)構(gòu)為
id fid name 三個字段
1 0 name1
2 1 name2
3 1 name3
4 3 name4
5 3 name5

比如是這種結(jié)構(gòu),假如當(dāng)前處理id為3的數(shù)據(jù)時,如何把相關(guān)的同級、父級、子級結(jié)構(gòu)全部查詢輸出?
意思是把這條數(shù)據(jù)的最頂級目錄 一直遍歷到最低級目錄的所有結(jié)構(gòu)查詢到
求個較為節(jié)約資源 速度快點的方法

回答
編輯回答
撥弦

啊,之前看過新的分級表設(shè)計,具體鏈接名字我忘了,所以直接告訴你設(shè)計方案吧。
字段: id(主鍵 ) top_id(原始 ID) pid(上級 ID) name(內(nèi)容) lv_num(所屬等級)
?,F(xiàn)在你看到這里,你可以思考下這樣設(shè)計的優(yōu)劣,如果能直接想明白是最好的,如果不能明白,請看下面:

每個分類通過記錄三個字段來實現(xiàn)管理,分別為 祖先ID top_id ,這是記錄該數(shù)據(jù)的最上級分類,而 pid 則記錄上級分類,lv_num 記錄當(dāng)前分類所屬的級別。這樣的話,如果要找到對應(yīng)分類下面的所有數(shù)據(jù),只需要通過 top_id 就能直接獲取到所有的,而如果只想要獲取下一級的則可以通過 pid 獲取到。如果要找到某個級別的,完全可以通過 lv_num 獲取到。如果要某個分類下面的同級則可以 pid and lv_num 就可以實現(xiàn)。最后,如果要找到某個大分類下面第幾級的所有分類則通過 top_id and lv_num 實現(xiàn)。

可以對比下其它設(shè)計優(yōu)劣進(jìn)行對比。

2018年5月19日 09:50
編輯回答
浪蕩不羈

建議新增字段,表示路徑

id fid name path
1 0 name1 1,
2 1 name2 1,2,
3 1 name3 1,3,
4 3 name4 1,3,4,
5 3 name5 1,3,5,

查詢1下面的 select * from xx where path like '1,%'
查詢2下面的 select * from xx where path like '1,2,%'

2017年11月24日 17:55