首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue3+TS+Node打造个人博客(数据库设计)

Vue3+TS+Node打造个人博客(数据库设计)

作者头像
Tusi
发布2022-03-14 14:15:31
5810
发布2022-03-14 14:15:31
举报
文章被收录于专栏:前端司南前端司南

原创@前端司南

本项目代码已开源,具体见: 前端工程:vue3-ts-blog-frontend[1] 后端工程:express-blog-backend[2]

一个博客系统应该有什么功能,相信大家都是非常熟悉的,其核心无非是文章分类创作。而像标签评论留言交流后台管理这些功能,都是锦上添花。

要实现这些功能,最关键的是先梳理各个功能之间的关系。提到关系,自然就会联想到关系型数据库。

在设计数据库前,需要先理清实体和实体之间的联系,这里会用到 E-R 图或者 UML 之类的建模语言来做一个概要设计。

但是从我这种非专业的数据库用户的视角来看,我觉得可以不拘泥于形式,不必局限于 E-R 图或者 UML,你也可以选择用思维导图这类的图形化表述工具。因为这只是一个概要设计阶段。

如上图所示,针对我的个人博客,我做了简单的实体和实体关系设计。

多对多关系

其中文章表article是核心,考虑到一篇文章可能关联多个分类category或标签tag,一个分类或标签下也会有多篇文章,所以我这里设计的都是多对多关系,用到了关系表。

关系表不会涉及很多字段。

主要是关系表中设计的两个外键起到关键作用。

根据这么一张关系表,就能完成多对多的关联关系。

一对多关系

文章下有评论,一篇文章可以有多条评论,文章article和评论comment的关系就是一对多的,这个是很好理解的。

对于这种一对多关系,我的设计是在评论表中用一个外键article_id来实现关联。

要查询某文章下的评论时,就可以依据条件article_id筛选出对应的评论数据。

SELECT * FROM comments WHERE article_id = 229;

子级关系

同样地,一条评论下也会有很多回复,针对回复,我是单独设计了reply表。commentreply也是一对多的关系,reply表中有comment_id外键关联到comment表。

除了对评论做回复,还可以针对某一条回复做回复,类似于这样:

而这种子级关系,就需要一个parent_id来做记录,根据parent_id串起来的关系,在业务侧我们就可以得到一棵回复树。

状态字段

很多业务都离不开状态的维护,比如数据的逻辑删除,文章的公开/私密处理,评论/回复的审核机制,这些都需要一些标志位来描述状态,同时提供一些业务接口来维护状态。

小结

本文是Vue3+TS+Node打造个人博客(数据库设计篇),主要介绍了我在为博客系统设计数据库时的一些主要思路和关注点,接下来将针对一些具体的业务实现来进行更详细的剖析,敬请期待!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-03-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 bin不懂二进制 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 多对多关系
  • 一对多关系
  • 子级关系
  • 状态字段
  • 小结
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档