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

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

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

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

回答
編輯回答
撥弦

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

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

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

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