- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我对标记数据库模式的 Toxi 解决方案有点头疼。我正在开发一个用户可以向其提交项目的系统,并且这些项目可以具有与之关联的标签。在阅读了 tagschemas 之后,我发现 Toxi 解决方案最适合我的需求。但是,我不完全确定我的计划是否正确,所以我想请教您对此的意见。
我将拥有三个数据库。items
包含 item_id
和其他tagmap
使用 item_id
和 tag_id
作为外键标签
包含tag_id
和tag_text
添加新项目时,我是否可以假设将标签添加到数据库的过程如下?
这意味着我们最终会在标签图中为每个项目的每个标签创建一个条目。这似乎是正确的,但我忍不住认为有一种更好的方法可以做到这一点,而不是在那里结束大量的条目......
至于编辑标签,我想到了以下过程,尽管我认为还有更好的方法我还没有找到。
我对第 3 点有点怀疑。有没有办法让我检查是否有任何标签已被删除,这样我就可以有选择地删除标签,而不是仅仅删除并重新添加它们?并且可以肯定的是:删除标记映射行时,相关项不会随之删除,因为它指向一个外键而不是一个外键,对吧?
此外,我可能想跟踪标签的使用次数,但我不想运行查询来计算每次需要显示标签的次数。我正在考虑让 cron 作业每小时或每两小时计算一次 tagmap 中每个 tag_id 的实例数,然后更新 tags 表中的 tag_use 值。这是正确的方法,还是有更好的方法?
回过头来看,这是相当多的文字。好吧,宁可太详细而不是遗漏信息,宁可问太多问题和学习很多新东西而不是问太少。很有可能我今天花了太多时间研究这个问题,明天一切都会变得更有意义。
提前致谢!
最佳答案
首先“toxi”不是一个标准术语。始终定义您的条款!或者至少提供相关链接。
现在回到问题本身......
I'll have three databases.
不,您将有 3 个表。
When adding a new item...
除了您可以使用 SQL 的基于集合的特性来“合并”其中的许多步骤之外,您几乎走在了正确的轨道上。例如,用标签标记项目 1:'tag1'、'tag2' 和 'tag3' 可以像这样完成...
INSERT IGNORE INTO tagmap (item_id, tag_id)
SELECT 1, tag_id FROM tags WHERE tag_text IN ('tag1', 'tag2', 'tag3');
IGNORE
允许此操作成功,即使 item 已经连接到其中一些标签。
这假设所有必需的标签都已在 tags
中。假设 tag.tag_id
是自动递增的,你可以做这样的事情来确保它们是:
INSERT IGNORE INTO tags (tag_text) VALUES ('tag1'), ('tag2'), ('tag3');
This means we'll end up with an entry in the tagmap for every tag for every item. It seems correct, but I can't help but think there's a better way to do that then ending up with a huge amount of entries there...
没有魔法。如果“项目连接到特定标签”是您要记录的知识片段,那么它必须在数据库中具有某种物理表示。
As for editing the tags...
你的意思是重新标记项目(而不是修改标签本身)?
要删除所有不在列表中的标签,请执行以下操作:
DELETE FROM tagmap
WHERE
item_id = 1
AND tag_id NOT IN (
SELECT tag_id FROM tags
WHERE tag_text IN ('tag1', 'tag3')
);
这将断开项目与除“tag1”和“tag3”之外的所有标签的连接。依次执行上面的 INSERT 和这个 DELETE 以“覆盖”添加和删除标签。
您可以在 SQL Fiddle 中使用所有这些.
And just to be sure: when deleting tagmap rows, the related items won't be deleted with it because it points to a foreign key instead of acting as one, right?
正确。 FK 的子端点不会触发引用操作(例如 ON DELETE CASCADE),只有父端点会。
顺便说一句,您使用此架构是因为您需要在 tags
中添加其他字段(在 tag_text
旁边),对吗?如果您这样做了,则不会因为所有连接都消失而丢失这些额外数据,这是理想的行为。
但是如果您只想要 tag_text
,您可以使用更简单的架构,其中删除所有连接与删除标签本身相同:
这不仅会简化 SQL,还会提供更好的 clustering .
乍一看,“toxi”可能看起来像是在节省空间,但实际上可能并非如此,因为它需要额外的表和索引(而且标签往往很短)。
Also, I may want to keep track of the amount of times a tag ... cron job ...
在你决定做这样的事情之前先测量一下。上面提到的我的 SQL Fiddle 在 tagmap
PK 中使用了非常谨慎的字段顺序,因此数据以对这种计数非常友好的方式聚集(记住:InnoDB tables are clustered)。在这成为问题之前,您必须拥有真正大量的项目(或需要异常高性能)。
无论如何,衡量的是真实的数据量!
关于mysql - 标记系统 : Toxi solution questions,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10506181/
Alexa 技能适用于第一个问题,但不适用于第二个问题。这是一个使用以下数组的困惑字母测验 var arr = [{"Q":"dcha","A":"chad"},{"Q":"goto","A":"to
我正在制作一个小问答 ios 应用程序。我希望第一个问题是随机的。我的代码如下。 let allQuestions = QuestionBank() var pickedAnswer : Bool =
我对 Dialogflow 比较陌生,我正在尝试创建一个医疗保健诊断语音聊天机器人,其工作方式如下。 用户体验 用户调用系统并受到聊天机器人的欢迎。 聊天机器人开始询问与分流相关的问题(例如,“您有慢
我正在尝试将一个表单(包含测试问题)提交到一个名为 Questions 的 mongo 集合中。我已经引用了运行服务器端代码的文件,我认为它应该都可以正常工作。这是我的代码: //add.html
import 'dart:async'; import 'question.dart'; import 'package:http/http.dart' as http; import 'dart:c
我想添加用户输入到列表中的任何字符串 run :- write('How many students you have: '),read(x),nl. enterNameOfStuden
我正在努力提高我的 JAVA 水平。现在我有一个关于线程的问题我不明白。 我尝试的代码是这样的, public class MyThread implements Runnable { pri
我正在为一个项目构建一个 XML 反序列化器,我经常遇到这种类型的代码情况: var myVariable = ParseNDecimal(xml.Element("myElement")) == n
我有一个 JSF 页面,它将创建一个新的 Comment。我将该页面的托管 bean 设为 RequestScoped 托管 bean。 @ManagedBean(name="PostComment"
房间和应用程序之间存在一对一的关系,意味着应用程序必须占用一个房间。如果我想获取未被应用占用的房间,如何写sql查询 最佳答案 select * from room r where not exist
我有一个 css 布局,其中我有一个单页网站 问题是我不想要滚动条所以我确实隐藏了溢出并且它工作正常但是当有不同的屏幕分辨率时,所以底部的内容被切断有没有办法解决这个问题 我的意思是,当内容适合首页时
我做了一个简单的算法,用于将整数转换为二进制,并将二进制作为字符串返回。目前,这些位被添加到列表的前面。在每一步连接字符串而不是附加到列表会更有效(就时间或空间而言)吗?为什么/为什么不? def t
我经常听说 mongodb 可以在一个集合级别执行原子性。您知道为什么以及如何将其与分片联系起来吗? replication 和 replicasets 之间的唯一区别是两者都是主/从(主要/次要),
我有几个关于线程的问题。能否请您澄清一下。 假设进程有一个或多个线程。如果进程被抢占/挂起,线程是否也被抢占或线程是否继续运行? 当挂起的进程被重新调度时,进程线程是否也被调度了?如果进程有进程有多个
我最近接受了一次采访,他问我单例设计模式是如何实现的,我告诉他使用静态变量和静态方法我们可以实现单例设计模式。 他似乎对答案满意但我想知道 我们可以有多少种不同的方式实现单例设计模式在 Java 中?
我以前使用 has_and_belongs_to_many,并已转换为 has_many :through。下面是它如何查找可以有很多用户玩的游戏列表。有了这个,我可以做 game.users 和 u
这是我的代码的骨架: var myArray: (Array | null); if (cnd) { myArray = []; myArray?.push(elt); // Question
使用ORLite时放置sqlite_unicode设置的正确位置在哪里? 最佳答案 不幸的是,没有一个真正好的地方。请参阅bug #61191: Enable sqllite_unicode in t
我承认我已经有一段时间没有使用 Perl 了,但这让我很难过。 这是问题: #!/usr/bin/perl use CGI::Carp qw(fatalsToBrowser); use DBI; pr
我有一个名为 Question 的模型。模型允许用户创建新问题。我正在尝试使用对象查询集填充多个表单。当我尝试使用查询集进行初始化时,会出现问题。我收到此错误 'Question' object i
我是一名优秀的程序员,十分优秀!