【发布时间】:2012-05-08 20:43:02
【问题描述】:
对于标签数据库模式的 Toxi 解决方案,我有点头疼。我正在开发一个用户可以提交项目的系统,这些项目可以有与之关联的标签。在阅读了 tagschemas 之后,我发现 Toxi 解决方案最适合我的需求。但是,我不完全确定我的计划是否正确,所以我想听听您对此的意见。
我将拥有三个数据库。
items 包含item_id 和其他
tagmap 使用 item_id 和 tag_id 作为外键
tags 包含tag_id 和tag_text
添加新项目时,我是否可以假设将标签添加到数据库的过程如下?
- 将提交的标签排序到数组中
- 对于数组中的每个标签:
- 从 tag_text 与当前标签匹配的标签中获取 tag_id
- 如果返回 0 行:
- 在标签表中添加标签
- 获取tag_id
- 将 item_id 和 tag_id 添加到 tagmap 中
- 完成(给用户一个好的,等等)
这意味着我们最终会在标签映射中为每个项目的每个标签创建一个条目。这似乎是正确的,但我不禁认为有一个更好的方法来做到这一点,而不是在那里结束大量的条目......
至于编辑标签,我已经想到了以下过程,虽然我认为还有更好的方法我还没有找到。
- 使用 item_id 获取标签并插入到可编辑字段中
- 用户进行更改。提交时:
- 从 tagmap 中删除 item_id 与正在编辑的行匹配的行
- 与上面列出的过程相同
我对那里的第 3 点有点怀疑。有没有办法让我检查是否有任何标签已被删除,这样我就可以有选择地删除标签,而不仅仅是删除并重新添加它们? 并且只是为了确定:当删除 tagmap 行时,相关项不会被删除,因为它指向一个外键而不是一个外键,对吧?
另外,我可能想跟踪标签的使用次数,但我不想运行查询来计算每次需要显示的次数。我正在考虑让一个 cron 作业每小时或每两小时计算一次 tagmap 中每个 tag_id 的实例数,然后更新 tags 表中的 tag_use 值。这是正确的方法,还是有更好的方法?
回想起来,那是相当大量的文字。 Welp,宁可太详细也不要遗漏信息,宁可问太多问题,学很多新东西,也不要问太少。 好机会我今天花了太多时间研究这个,明天就会更有意义。
提前致谢!
【问题讨论】:
-
为了后代,“毒液”来自this blog post。
标签: mysql database-design database-schema tagging