关于博客标签系统的设计

发布于 2022-09-01 18:53:07 字数 514 浏览 37 评论 0

各位好,我目前正在学习PHP+MYSQL设计个人博客。
目前遇到了一个问题,想与大家一起讨论。

在博客系统数据库设计中,我将系统分为三个部分:
(括号内为数据库各字段)
1.目录/归档(id, title, slug)
2.文章(id, archiveid, title, slug, content, tags...)
3.标签(id, tagname, articleid, count)

目前遇到的一个问题是如何通过标签进行文章查询。
大家看一下我的思路对不对。

文章的tags字段 varchar(32)存放 以,隔开的标签
标签的articleid字段 varchar(32)存放 以,隔开的文章id

当写完一篇文章进行存储的时候,文章tags分割开,如果该标签存在,就update一下标签的articleid,加入该文章id,count+1。如果标签不存在,标签表新建一行。

当查询文章时,将标签articleid以,隔开转为array,再依次查询文章。

大家觉得如何呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

终难愈 2022-09-08 18:53:07

既然文章tags字段存储了逗号分割的tag,那么根据tag查找文章的时候直接使用like语法查询就好。
没必要在tag表再保存articleid。。。多余了。

如歌彻婉言 2022-09-08 18:53:07

3其实可以考虑拆表

一个表,存储tag信息,如id,tagname,createtime

另一个表可以用来对应tag和文章

不过说回来,考虑到一个文章可以有多个tag似乎这样也不太好

还是用postgresql之类的好了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文