亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2014年07月25日 15:32:52   投稿:junjie  
這篇文章主要介紹了3種高效的Tags標(biāo)簽系統(tǒng)數(shù)據(jù)庫設(shè)計方案分享,現(xiàn)在主流的博客、CMS系統(tǒng)都有一個標(biāo)簽系統(tǒng),本文就探討它的數(shù)據(jù)庫設(shè)計方式,需要的朋友可以參考下

需求背景

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

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

此方案分為2個表:

1.Tag表
2.文章表

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

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

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

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

ID #文章ID
title #文章標(biāo)題
tags #tags列表,多個以,分割
tagid #tags的ID 多個以,分割
...

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

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

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

Tag表:

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

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

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

tagid
aid

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

ID #文章ID
title #文章標(biāo)題
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ù)庫強(qiáng)大的線性查詢能力。

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

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

相關(guān)文章

  • MySQL不使用order by實現(xiàn)排名的三種思路總結(jié)

    MySQL不使用order by實現(xiàn)排名的三種思路總結(jié)

    ORDER BY語句用于根據(jù)指定的列對結(jié)果集進(jìn)行排序,在日常開發(fā)中也經(jīng)常會用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實現(xiàn)排名的三種思路,需要的朋友可以參考下
    2021-06-06
  • 大幅提升MySQL中InnoDB的全表掃描速度的方法

    大幅提升MySQL中InnoDB的全表掃描速度的方法

    這篇文章主要介紹了大幅提升MySQL中InnoDB的全表掃描速度的方法,作者談到了預(yù)讀取和多次async I/O請求等方法,減小InnoDB對MySQL速度的影響,需要的朋友可以參考下
    2015-06-06
  • nacos無法連接mysql的解決方法

    nacos無法連接mysql的解決方法

    這篇文章主要介紹了nacos無法連接mysql的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Mysql啟動報ERROR:2002的分析與解決

    Mysql啟動報ERROR:2002的分析與解決

    這篇文章主要給大家介紹了關(guān)于Mysql啟動時報ERROR:2002問題的分析與解決方法,文中通過示例代碼介紹將該問題分析的非常詳細(xì),對同樣遇到這個問題的朋友們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-08-08
  • ubuntu16.04.1下 mysql安裝和卸載圖文教程

    ubuntu16.04.1下 mysql安裝和卸載圖文教程

    這篇文章主要介紹了ubuntu16.04.1下 mysql安裝和卸載圖文教程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11
  • mysql如何在已有數(shù)據(jù)庫上統(tǒng)一字符集

    mysql如何在已有數(shù)據(jù)庫上統(tǒng)一字符集

    這篇文章主要介紹了mysql如何在已有數(shù)據(jù)庫基礎(chǔ)上換字符集,數(shù)據(jù)庫里面,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是latin1的,部分?jǐn)?shù)據(jù)表和數(shù)據(jù)是UTF8,還有部分表,表結(jié)構(gòu)是utf8而數(shù)據(jù)是latin1,下面說一下,怎么樣字符集統(tǒng)一成utf8,需要的朋友可以參考下
    2019-06-06
  • Sysbench對Mysql進(jìn)行基準(zhǔn)測試過程解析

    Sysbench對Mysql進(jìn)行基準(zhǔn)測試過程解析

    這篇文章主要介紹了Sysbench對Mysql進(jìn)行基準(zhǔn)測試過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • MySQL的MaxIdleConns不合理,會變成短連接的原因

    MySQL的MaxIdleConns不合理,會變成短連接的原因

    這篇文章主要介紹了MySQL的MaxIdleConns不合理,會變成短連接的原因,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-01-01
  • 21條MySQL優(yōu)化建議(經(jīng)驗總結(jié))

    21條MySQL優(yōu)化建議(經(jīng)驗總結(jié))

    這篇文章主要介紹了21條MySQL優(yōu)化建議,均來自個人的實戰(zhàn)經(jīng)驗總結(jié),需要的朋友可以參考下
    2014-07-07
  • mysql 5.7.17 winx64安裝配置教程

    mysql 5.7.17 winx64安裝配置教程

    這篇文章主要為大家詳細(xì)介紹了mysql 5.7.17 winx64安裝配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03

最新評論