三维(或更多)标签系统?PHP / MySQL数据库架构


Three-Dimensional (or more) Tagging System? PHP / MySQL Database Architecture

很明显,我提出了一个头脑风暴的问题。或者我是个新手,找不到任何明显的答案:

如何实现一个标签系统,其中每个标签与网站的每个用户都有特定的关系?

我试图实现的一个非常简单的例子是,系统跟踪用户对每个标签的页面点击。例如,多个标签关键字被"标记"到网站的每个页面。一个关于环境科学的页面可能会被贴上"生物学"answers"社会学"这样的关键词。当用户A访问该页面时,一个数字增加1,计算用户A每次浏览"生物学"的次数,并计算"社会学"的次数。

因此,我们最终得到的记录显示了一个人有多喜欢一个特定的标签。

对于MySQL来说,最有效的方法是什么?是否有可能将其工作到如下所示的双表系统中?
Table 1: Tags
 - tag_title
 - tagged_pages
 - user_likes
Table 2: Users
 - user_id

添加更多的表列是完全可以的。我想避免的是重复标签表和其中的所有记录。

到目前为止,我所想到的是将user_likes字段格式化为每个标签:101-12, 99-3, 156-14…等。然后使用PHP的explot_()将user_id与点赞数分开。

非常感谢你的创意见解!

不要在一列中放置多个信息。这是规范化的第一条规则,你真的不应该违反它。

我认为你需要更多的表来正确地构建这个(并正确地规范化)

users
    id
    name
tags
    id
    name
pages
    id
page_tags
    page_id
    tag_id
user_page_hits
    user_id
    page_id
    hits

现在,如果你想知道用户有多喜欢某个标签,你可以在这些表上创建一个VIEW,比如

user_tag_hits
    as select u.name, t.name, sum(uph.hits) hits from users u
              join user_page_hits uph on uph.user_id = u.id
              join page_tags pt on pt.page_id = uph.page_id
              join tags t on t.id = pt.tag_id
              group by u.name, t.name

会产生像

这样的结果
username tagname  hits
me  tag1    112
me  tag2    112
me  tag3    70
me  tag4    4
me  tag5    4