关于博客标签系统的设计
各位好,我目前正在学习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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
既然文章tags字段存储了逗号分割的tag,那么根据tag查找文章的时候直接使用like语法查询就好。
没必要在tag表再保存articleid。。。多余了。
3其实可以考虑拆表
一个表,存储tag信息,如id,tagname,createtime
另一个表可以用来对应tag和文章
不过说回来,考虑到一个文章可以有多个tag似乎这样也不太好
还是用postgresql之类的好了