ASP.NET 无限级分类实现实例(深度字段)
下圖中紅色箭頭是父類 而且屬于根目錄級別。
下面?zhèn)€字段為:ID 父ID 類型名稱 深度 排序
前面3個字段沒有什么可解釋的,做過無限級分類設(shè)計(jì)的人都應(yīng)該清楚
而第5個字段排序字段ID:43的23排序代表他在這張表排在23的根目錄
而23下面的23,01 說明他是2級分類,排在23下面的第01個,也是支持99級分類。
而我比較特殊的是多了個深度字段,大家可以看上圖數(shù)據(jù),
ID:40的 深度字段也是40,ID:43的 深度字段也是43。
而他們的下級子類,后面都跟了個 "," 加自己的ID。
2級子類的深度字段就是(父類ID,自己ID),以此類推,3級分類深度就是(總父類ID,上級父類ID,自己ID),后面不用說了吧。
看到這里可以在看看上面的圖,因?yàn)槲疫@個網(wǎng)站程序,只有2級分類而已。
當(dāng)然還有中間那個 "," 完全可以自己用自己喜歡的字符 你用 "|" "-" "_"一切字符都可以 但是建議一定要有個字符。
是因?yàn)樵诔绦蚶锖梅指铋_來,而且也很直觀,完全可以自己在數(shù)據(jù)庫修改分類數(shù)據(jù)(因?yàn)榫W(wǎng)站分類一般定了很少改動,第一次完全可以在數(shù)據(jù)庫中加上所有分類)
談到這里,在來說說這個字段有什么功能和好處,咋一看這個字段好象很浪費(fèi)資源,下面聽我細(xì)細(xì)道來:
在行業(yè)門戶網(wǎng)站里經(jīng)常有這樣的需求,需要查出某個分類下的所有子分類,如果沒有這個字段的話,
那查出下面的所有字分類,SQL語句就應(yīng)該要很長了,或者使用遞歸:根據(jù)1級父類ID查出所有2級分類--根據(jù)2級分類ID--查出所有3級分類,如果有多級分類的話,這樣的遞歸效率可想而知。
如果有這個字段(并且數(shù)據(jù)已對應(yīng)加好),一切就變得美好多了,讓你很輕松就能查出某個分類下所有的子類,下面看個圖:
有沒有看明白,只需要帶上條件,深度 like ‘40%’ 注意后面的%一定要帶 這樣才能查出包括自己在內(nèi)所有的子類,如果不需要帶上自己,我只要自己下面的所有子類,很簡單,深度 like ‘40,' 只需要把%號換成你自己設(shè)定的分割符就行了(只就是我強(qiáng)調(diào)一定要分割符的作用)。
這樣是不是很輕松,而且如果后面帶上 order by Nt_OrderBy 是不是自動就根據(jù)你數(shù)據(jù)庫的排序數(shù)據(jù) 排好了序呢
最后總結(jié)一下,雖然這個字段好用,但是在添加更新分類數(shù)據(jù)的同時(shí),也往往加大了添加更新的邏輯程序,但是為了性能,為了SQL語句的方便,這一切是值得的。
轉(zhuǎn)載于:https://www.cnblogs.com/xiaopohou/archive/2011/09/15/2176812.html
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的ASP.NET 无限级分类实现实例(深度字段)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ASP编程中的Microsoft JSc
- 下一篇: 【求解】未定义的析构函数