天天看點

3種高效的Tags标簽系統資料庫設計方案分享

需求背景

目前主流的部落格系統、CMS都會有一個TAG标簽系統,不僅可以讓内容連結的結構化增強,而且可以讓文章根據Tag來區分。相比傳統老式的Keyword模式,這種Tag模式可以單獨的設計一個Map的映射表來增加系統的負載和查詢的效率。

資料庫設計方案1

此方案分為2個表:

1.Tag表

2.文章表

Tag表表結構:

代碼如下:

tagid # tag标簽的ID

tagname #tag内容

num #目前Tag的引用個數

文章表結構:

ID #文章ID

title #文章标題

tags #tags清單,多個以,分割

tagid #tags的ID 多個以,分割

...

此種方式Tag标簽主要内容儲存在 文章表 中,對于Tag表的壓力較小,隻是添加的時候更新一下Tag的引用數量,但是查詢的時候效率不足,不是好辦法

資料庫設計方案2

第二種方案使用2個Tag表,其中一個儲存Tag資訊,另一個儲存映射資訊:

Tag表:

Tagmap表

tagid

aid

文章表

這種形式,每次釋出内容和修改内容的時候 都去更新一下Tag表和 Tagmap表。

查詢的時候需要從Tagmap表中查找響應的文章ID,然後使用文章ID去查詢具體的文章資訊,因為每次查詢都是使用索引,是以效率較高。

資料庫設計方案3

前兩種方案都是使用純粹的Mysql來設計的,第三種方案将使用Nosql的魅力來設計。

基本結構同方案2,隻是在Tag表和Tagmap表中使用mongo/redis這樣的nosql資料庫伺服器,這樣可以發揮nosql資料庫強大的線性查詢能力。

1) 第一種方式的表結構設計與方案2完全相同,隻是資料庫伺服器換了。

2)其他的方案,當然是發揮Nosql的線性能力來設計存儲的Key了,尤其是使用redis的時候,使用的Key的結構可以完美的提高查詢效率

如何聯系我:【萬裡虎】www.bravetiger.cn

【QQ】3396726884 (咨詢問題100元起,幫助解決問題500元起)

【部落格】http://www.cnblogs.com/kenshinobiy/