3種高效的Tags標(biāo)簽系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)方案分享
需求背景
目前主流的博客系統(tǒng)、CMS都會(huì)有一個(gè)TAG標(biāo)簽系統(tǒng),不僅可以讓內(nèi)容鏈接的結(jié)構(gòu)化增強(qiáng),而且可以讓文章根據(jù)Tag來(lái)區(qū)分。相比傳統(tǒng)老式的Keyword模式,這種Tag模式可以單獨(dú)的設(shè)計(jì)一個(gè)Map的映射表來(lái)增加系統(tǒng)的負(fù)載和查詢(xún)的效率。
數(shù)據(jù)庫(kù)設(shè)計(jì)方案1
此方案分為2個(gè)表:
1.Tag表
2.文章表
Tag表表結(jié)構(gòu):
tagid # tag標(biāo)簽的ID
tagname #tag內(nèi)容
num #當(dāng)前Tag的引用個(gè)數(shù)
文章表結(jié)構(gòu):
ID #文章ID
title #文章標(biāo)題
tags #tags列表,多個(gè)以,分割
tagid #tags的ID 多個(gè)以,分割
...
此種方式Tag標(biāo)簽主要內(nèi)容保存在 文章表 中,對(duì)于Tag表的壓力較小,只是添加的時(shí)候更新一下Tag的引用數(shù)量,但是查詢(xún)的時(shí)候效率不足,不是好辦法
數(shù)據(jù)庫(kù)設(shè)計(jì)方案2
第二種方案使用2個(gè)Tag表,其中一個(gè)保存Tag信息,另一個(gè)保存映射信息:
Tag表:
tagid # tag標(biāo)簽的ID
tagname #tag內(nèi)容
num #當(dāng)前Tag的引用個(gè)數(shù)
Tagmap表
tagid
aid
文章表
ID #文章ID
title #文章標(biāo)題
tags #tags列表,多個(gè)以,分割
...
這種形式,每次發(fā)布內(nèi)容和修改內(nèi)容的時(shí)候 都去更新一下Tag表和 Tagmap表。
查詢(xún)的時(shí)候需要從Tagmap表中查找響應(yīng)的文章ID,然后使用文章ID去查詢(xún)具體的文章信息,因?yàn)槊看尾樵?xún)都是使用索引,所以效率較高。
數(shù)據(jù)庫(kù)設(shè)計(jì)方案3
前兩種方案都是使用純粹的Mysql來(lái)設(shè)計(jì)的,第三種方案將使用Nosql的魅力來(lái)設(shè)計(jì)。
基本結(jié)構(gòu)同方案2,只是在Tag表和Tagmap表中使用mongo/redis這樣的nosql數(shù)據(jù)庫(kù)服務(wù)器,這樣可以發(fā)揮nosql數(shù)據(jù)庫(kù)強(qiáng)大的線(xiàn)性查詢(xún)能力。
1) 第一種方式的表結(jié)構(gòu)設(shè)計(jì)與方案2完全相同,只是數(shù)據(jù)庫(kù)服務(wù)器換了。
2)其他的方案,當(dāng)然是發(fā)揮Nosql的線(xiàn)性能力來(lái)設(shè)計(jì)存儲(chǔ)的Key了,尤其是使用redis的時(shí)候,使用的Key的結(jié)構(gòu)可以完美的提高查詢(xún)效率
相關(guān)文章
MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)
ORDER BY語(yǔ)句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序,在日常開(kāi)發(fā)中也經(jīng)常會(huì)用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實(shí)現(xiàn)排名的三種思路,需要的朋友可以參考下2021-06-06Mysql啟動(dòng)報(bào)ERROR:2002的分析與解決
這篇文章主要給大家介紹了關(guān)于Mysql啟動(dòng)時(shí)報(bào)ERROR:2002問(wèn)題的分析與解決方法,文中通過(guò)示例代碼介紹將該問(wèn)題分析的非常詳細(xì),對(duì)同樣遇到這個(gè)問(wèn)題的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-08-08mysql如何在已有數(shù)據(jù)庫(kù)上統(tǒng)一字符集
這篇文章主要介紹了mysql如何在已有數(shù)據(jù)庫(kù)基礎(chǔ)上換字符集,數(shù)據(jù)庫(kù)里面,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是latin1的,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是UTF8,還有部分表,表結(jié)構(gòu)是utf8而數(shù)據(jù)是latin1,下面說(shuō)一下,怎么樣字符集統(tǒng)一成utf8,需要的朋友可以參考下2019-06-06Sysbench對(duì)Mysql進(jìn)行基準(zhǔn)測(cè)試過(guò)程解析
這篇文章主要介紹了Sysbench對(duì)Mysql進(jìn)行基準(zhǔn)測(cè)試過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11MySQL的MaxIdleConns不合理,會(huì)變成短連接的原因
這篇文章主要介紹了MySQL的MaxIdleConns不合理,會(huì)變成短連接的原因,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下2021-01-0121條MySQL優(yōu)化建議(經(jīng)驗(yàn)總結(jié))
這篇文章主要介紹了21條MySQL優(yōu)化建議,均來(lái)自個(gè)人的實(shí)戰(zhàn)經(jīng)驗(yàn)總結(jié),需要的朋友可以參考下2014-07-07