ASP.NET無限級分類之美好欄位(深度欄位)

來源:互聯網
上載者:User

下圖中紅色箭頭是父類 而且屬於根目錄層級。

下面個欄位為:ID  父ID  類型名稱  深度  排序

前面3個欄位沒有什麼可解釋的,做過無限級分類設計的人都應該清楚

而第5個欄位排序欄位ID:43的23排序代表他在這張表排在23的根目錄

而23下面的23,01 說明他是2級分類,排在23下面的第01個,也是支援99級分類。

而我比較特殊的是多了個深度欄位,大家可以看上圖資料,

ID:40的 深度欄位也是40,ID:43的 深度欄位也是43。

而他們的下級子類,後面都跟了個 "," 加自己的ID。

2級子類的深度欄位就是(父類ID,自己ID),以此類推,3級分類深度就是(總父類ID,上級父類ID,自己ID),後面不用說了吧。

看到這裡可以在看看上面的圖,因為我這個網站程式,只有2級分類而已。

當然還有中間那個 "," 完全可以自己用自己喜歡的字元 你用 "|" "-" "_"一切字元都可以 但是建議一定要有個字元。

是因為在程式裡好分割開來,而且也很直觀,完全可以自己在資料庫修改分類資料(因為網站分類一般定了很少改動,第一次完全可以在資料庫中加上所有分類)

談到這裡,在來說說這個欄位有什麼功能和好處,咋一看這個欄位好象很浪費資源,下面聽我細細道來:

在行業門戶網站裡經常有這樣的需求,需要查出某個分類下的所有子分類,如果沒有這個欄位的話,

那查出下面的所有字分類,SQL語句就應該要很長了,或者使用遞迴:根據1級父類ID查出所有2級分類--根據2級分類ID--查出所有3級分類,如果有多級分類的話,這樣的遞迴效率可想而知。

如果有這個欄位(並且資料已對應加好),一切就變得美好多了,讓你很輕鬆就能查出某個分類下所有的子類,下面看個圖:

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.