MYSQL教程3种高效的Tags标签系统数据库设计方案分享

MYSQL教程3种高效的Tags标签系统数据库设计方案分享,第1张

概述介绍《MYSQL教程3种高效的Tags标签系统数据库设计方案分享》开发教程,希望对您有用。

《MysqL教程3种高效的Tags标签系统数据库设计方案分享》要点:
本文介绍了MysqL教程3种高效的Tags标签系统数据库设计方案分享,希望对您有用。如果有疑问,可以联系我们。

需求背景MysqL入门

目前主流的博客系统、CMS都会有一个TAG标签系统,不仅可以让内容链接的结构化增强,而且可以让文章根据Tag来区分.相比传统老式的Keyword模式,这种Tag模式可以单独的设计一个Map的映射表来增加系统的负载和查询的效率.MysqL入门

数据库设计方案1MysqL入门

此方案分为2个表:MysqL入门

1.Tag表
2.文章表MysqL入门

Tag表表结构:
MysqL入门

代码如下:
tagID # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数

文章表结构:
代码如下:
ID #文章ID
Title #文章标题
Tags #Tags列表,多个以,分割
tagID #Tags的ID 多个以,分割
...

此种方式Tag标签主要内容保存在 文章表 中,对于Tag表的压力较小,只是添加的时候更新一下Tag的引用数量,但是查询的时候效率不足,不是好办法MysqL入门

数据库设计方案2MysqL入门

第二种方案使用2个Tag表,其中一个保存Tag信息,另一个保存映射信息:MysqL入门

Tag表:
MysqL入门

代码如下:
tagID # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数

Tagmap表
代码如下:
tagID
aID

文章表
代码如下:
ID #文章ID
Title #文章标题
Tags #Tags列表,分割
...

这种形式,每次发布内容和修改内容的时候 都去更新一下Tag表和 Tagmap表.MysqL入门

查询的时候需要从Tagmap表中查找响应的文章ID,然后使用文章ID去查询具体的文章信息,因为每次查询都是使用索引,所以效率较高.MysqL入门

数据库设计方案3MysqL入门

前两种方案都是使用纯粹的MysqL来设计的,第三种方案将使用Nosql的魅力来设计.MysqL入门

基本结构同方案2,只是在Tag表和Tagmap表中使用mongo/redis这样的nosql数据库服务器,这样可以发挥nosql数据库强大的线性查询能力.MysqL入门

1) 第一种方式的表结构设计与方案2完全相同,只是数据库服务器换了.MysqL入门

2)其他的方案,当然是发挥Nosql的线性能力来设计存储的Key了,尤其是使用redis的时候,使用的Key的结构可以完美的提高查询效率
MysqL入门

总结

以上是内存溢出为你收集整理的MYSQL教程3种高效的Tags标签系统数据库设计方案分享全部内容,希望文章能够帮你解决MYSQL教程3种高效的Tags标签系统数据库设计方案分享所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1161455.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存