首页 > 关于博客标签系统的设计

关于博客标签系统的设计

各位好,我目前正在学习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,再依次查询文章。

大家觉得如何呢?


3其实可以考虑拆表

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

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

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

还是用postgresql之类的好了


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

【热门文章】
【热门文章】