gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 02:28:51 25 4
gpt4 key购买 nike

很明显,我提出了一个需要头脑 Storm 的问题。那,或者我太菜鸟了,看不到任何明显的答案:

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

我试图实现的一个非常简单的例子是系统跟踪用户对每个标签的页面点击情况。例如,多个标签关键字被“标记”到网站的每个页面。关于环境科学的页面可能会被标记为“生物学”和“社会学”等关键字。当用户 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 与点赞数分开。

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

最佳答案

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

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

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

关于php - 三维(或更多)标注系统? PHP/MySQL 数据库架构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16100814/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com