• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 3种高效的Tags标签系统数据库设计方案分享

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了tags标签,struts tags标签库,wish tags标签,帝国cms tags标签,tags标签管理等相关知识,希望本文的分享对您有所帮助

需求背景

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

数据库设计方案1

此方案分为2个表:

1.Tag表
2.文章表

Tag表表结构:
tagid # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数
</div>
文章表结构:
ID #文章ID
title #文章标题
tags #tags列表,多个以,分割
tagid #tags的ID 多个以,分割
...
</div>

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

数据库设计方案2

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

Tag表:
tagid # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数
</div>
Tagmap表
tagid
aid
</div>
文章表
ID #文章ID
title #文章标题
tags #tags列表,多个以,分割
...
</div>

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

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

数据库设计方案3

前两种方案都是使用纯粹的Mysql来设计的,第三种方案将使用Nosql的魅力来设计。

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

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

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

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2018-12-05SQL Server数据库的高性能优化经验总结
  • 2018-12-05实例详解IOS 数据库升级数据迁移
  • 2018-12-05ubuntu linux下使用Qt连接MySQL数据库的方法
  • 2018-12-05MySql 安装时的1045错误
  • 2018-12-05Oracle中大批量删除数据的方法
  • 2018-12-05SqlServer 2005 T-SQL Query 学习笔记(1)
  • 2018-12-05SQL处理多级分类,查询结果呈树形结构
  • 2018-12-05Oracle Index 的三个问题
  • 2017-05-11解析MySQL数据库性能优化的六大技巧
  • 2017-05-11SQL语句中SUM与COUNT的区别深入分析

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • sql中用JOIN USING如何简化JOIN ON的实例
    • MySQL操作数据库和表的常用命令新手教程
    • 什么是blob,mysql blob大小配置介绍
    • mysqldump定时备份
    • MYSQL安装时解决要输入current root password的解决方法
    • MongoDB进阶篇之动态字段设计
    • 利用MySQL加密函数保护Web网站敏感数据的方法分享
    • MSSQL 基本语法及实例操作语句
    • MySql安装与卸载详细教程
    • 阿里云服务器新建用户具体方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有