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

标签 php mysql database-design tagging

很明显,我提出了一个头脑 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 ...ETC。然后使用 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/

相关文章:

sql-server - 这种情况下最好的数据库结构是什么?

mysql - 事件提要实现 - 它会扩展吗?

java - 配置 Tomcat 以便我可以将 JSP 页面连接到 MySQL

mysql - 使用 select 命令验证以日期时间格式存储在 mysql 中的日期小于当前用户输入的日期

javascript - 设置在选择下拉列表中选择的值

php - 在关系数据库中,如何从不同的表中获取最后的插入 ID

mysql - 按上午和下午时间订购

design-patterns - 如何正确存储与 Microsoft Azure 表存储的数据关系?

php - MySQL - 私有(private)帖子显示

php - Docker MySQL mysqli::real_connect():(HY000/2002):连接被拒绝