2

很明显,我出来是带着一个头脑风暴的问题。那,或者我太菜鸟了,看不到任何明显的答案:

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

我试图实现的一个非常简单的例子是系统跟踪用户为每个标签所做的页面点击的情况。例如,多个标签关键字被“标记”到网站的每个页面。关于环境科学的页面可能会被标记为“生物学”和“社会学”等关键字。当用户 A 访问该页面时,用户 A 每次查看“生物学”时都会将一个数字加 1,而“社会学”则会再计算一次。

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

使用 MySQL 执行此操作的最有效方法是什么,是否可以将其用于如下所示的两表系统?

Table 1: Tags

 - tag_title
 - tagged_pages
 - user_likes

Table 2: Users

 - user_id

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

到目前为止,我想出的只是将user_likes每个标签的字段格式设置为:101-12, 99-3, 156-14...等。然后使用 PHP explode() 将 user_id 与喜欢的数量分开。

非常感谢您的创造性见解!

4

1 回答 1

2

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

我认为您需要更多表来正确构建它(并正确规范化它)

users
    id
    name

tags
    id
    name

pages
    id

page_tags
    page_id
    tag_id

user_page_hits
    user_id
    page_id
    hits

现在,如果您想知道用户对某个标签的喜爱程度,您可以在这些表上创建一个视图,例如

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
于 2013-04-19T10:29:40.810 回答