我对标签数据库模式的 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 点有点怀疑。有没有办法让我检查是否有任何标签已被删除,这样我就可以有选择地删除标签,而不仅仅是删除并重新添加它们?只是为了确定:当删除标记映射行时,相关项目不会被删除,因为它指向一个外键而不是一个外键,对吧?
此外,我可能想跟踪使用标签的次数,但我不想运行查询来计算每次需要显示的次数。我正在考虑让 cron 作业每小时或每两小时计算一次 tagmap 中每个 tag_id 的实例数,然后更新 tags 表中的 tag_use 值。这是正确的方法,还是有更好的方法?
回想起来,那是相当大量的文字。Welp,与其说太详细,不如说漏掉信息,与其问太少,不如问太多问题,学很多新东西。好机会我今天花了太多时间研究这个,明天一切都会变得更有意义。
提前致谢!