国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > 幫助中心 > 正文

3種高效的Tags標簽系統(tǒng)數(shù)據(jù)庫設(shè)計方案分享

2024-07-09 22:47:46
字體:
供稿:網(wǎng)友

需求背景

目前主流的博客系統(tǒng)、CMS都會有一個TAG標簽系統(tǒng),不僅可以讓內(nèi)容鏈接的結(jié)構(gòu)化增強,而且可以讓文章根據(jù)Tag來區(qū)分。相比傳統(tǒng)老式的Keyword模式,這種Tag模式可以單獨的設(shè)計一個Map的映射表來增加系統(tǒng)的負載和查詢的效率。

數(shù)據(jù)庫設(shè)計方案1

此方案分為2個表:

1.Tag表
2.文章表

Tag表表結(jié)構(gòu):

復(fù)制代碼 代碼如下:

tagid # tag標簽的ID
tagname #tag內(nèi)容
num #當(dāng)前Tag的引用個數(shù)

文章表結(jié)構(gòu):
復(fù)制代碼 代碼如下:

ID #文章ID
title #文章標題
tags #tags列表,多個以,分割
tagid #tags的ID 多個以,分割
...

此種方式Tag標簽主要內(nèi)容保存在 文章表 中,對于Tag表的壓力較小,只是添加的時候更新一下Tag的引用數(shù)量,但是查詢的時候效率不足,不是好辦法

數(shù)據(jù)庫設(shè)計方案2

第二種方案使用2個Tag表,其中一個保存Tag信息,另一個保存映射信息:

Tag表:

復(fù)制代碼 代碼如下:

tagid # tag標簽的ID
tagname #tag內(nèi)容
num #當(dāng)前Tag的引用個數(shù)

Tagmap表
復(fù)制代碼 代碼如下:

tagid
aid

文章表
復(fù)制代碼 代碼如下:

ID #文章ID
title #文章標題
tags #tags列表,多個以,分割
...

這種形式,每次發(fā)布內(nèi)容和修改內(nèi)容的時候 都去更新一下Tag表和 Tagmap表。

查詢的時候需要從Tagmap表中查找響應(yīng)的文章ID,然后使用文章ID去查詢具體的文章信息,因為每次查詢都是使用索引,所以效率較高。

數(shù)據(jù)庫設(shè)計方案3

前兩種方案都是使用純粹的Mysql來設(shè)計的,第三種方案將使用Nosql的魅力來設(shè)計。

基本結(jié)構(gòu)同方案2,只是在Tag表和Tagmap表中使用mongo/redis這樣的nosql數(shù)據(jù)庫服務(wù)器,這樣可以發(fā)揮nosql數(shù)據(jù)庫強大的線性查詢能力。

1) 第一種方式的表結(jié)構(gòu)設(shè)計與方案2完全相同,只是數(shù)據(jù)庫服務(wù)器換了。

2)其他的方案,當(dāng)然是發(fā)揮Nosql的線性能力來設(shè)計存儲的Key了,尤其是使用redis的時候,使用的Key的結(jié)構(gòu)可以完美的提高查詢效率

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 抚州市| 壤塘县| 葫芦岛市| 临朐县| 玛曲县| 侯马市| 仁化县| 勐海县| 沈丘县| 运城市| 独山县| 民丰县| 科技| 南岸区| 乌恰县| 报价| 宾川县| 乳源| 遂昌县| 庆元县| 且末县| 泉州市| 开远市| 乐清市| 错那县| 盐池县| 寻乌县| 拉萨市| 万年县| 安顺市| 麟游县| 电白县| 百色市| 桓台县| 焉耆| 湖南省| 武邑县| 惠来县| 英吉沙县| 丰县| 长沙市|