时间:2021-05-25
需求背景
目前主流的博客系统、CMS都会有一个TAG标签系统,不仅可以让内容链接的结构化增强,而且可以让文章根据Tag来区分。相比传统老式的Keyword模式,这种Tag模式可以单独的设计一个Map的映射表来增加系统的负载和查询的效率。
数据库设计方案1
此方案分为2个表:
1.Tag表
2.文章表
Tag表表结构:
复制代码 代码如下:
tagid # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数
文章表结构:
复制代码 代码如下:
ID #文章ID
title #文章标题
tags #tags列表,多个以,分割
tagid #tags的ID 多个以,分割
...
此种方式Tag标签主要内容保存在 文章表 中,对于Tag表的压力较小,只是添加的时候更新一下Tag的引用数量,但是查询的时候效率不足,不是好办法
数据库设计方案2
第二种方案使用2个Tag表,其中一个保存Tag信息,另一个保存映射信息:
Tag表:
复制代码 代码如下:
tagid # tag标签的ID
tagname #tag内容
num #当前Tag的引用个数
Tagmap表
复制代码 代码如下:
tagid
aid
文章表
复制代码 代码如下:
ID #文章ID
title #文章标题
tags #tags列表,多个以,分割
...
这种形式,每次发布内容和修改内容的时候 都去更新一下Tag表和 Tagmap表。
查询的时候需要从Tagmap表中查找响应的文章ID,然后使用文章ID去查询具体的文章信息,因为每次查询都是使用索引,所以效率较高。
数据库设计方案3
前两种方案都是使用纯粹的Mysql来设计的,第三种方案将使用Nosql的魅力来设计。
基本结构同方案2,只是在Tag表和Tagmap表中使用mongo/redis这样的nosql数据库服务器,这样可以发挥nosql数据库强大的线性查询能力。
1) 第一种方式的表结构设计与方案2完全相同,只是数据库服务器换了。
2)其他的方案,当然是发挥Nosql的线性能力来设计存储的Key了,尤其是使用redis的时候,使用的Key的结构可以完美的提高查询效率
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
以WEB技术为数据库,将数据库技术与WEB技术直接接轨。此种设计方案与其他方案相比较为理想,只需在局域网及单机上安装此种设计方案就可将数据库技术与WEB技术直接
数据库结构产生的安全问题。电子商务企业网站在数据库开发的过程中,由于网站开发者与数据库设计工作人员共同制定的网站数据库系统结构设计方案不是很完善,容易出现导致网
数据库结构的安全隐患。在建设电子商务网站的前期,网站数据库的设计方案不完善也会使数据库的结构存在安全隐患,主要体现在以下3个方面:(1)数据库文件的存放位置比较
数据库结构的安全隐患。电子商务网站建设前期,开发者与设计人员制定的数据库设计方案不够完善,一般体现在以下三个方面:⑴默认了固定、有规律的数据库文件的存放位置。比
dbms是数据库管理系统,数据库管理系统(英语:DatabaseManagementSystem,缩写:DBMS)是一种针对对象数据库,为管理数据库而设计的大型