- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我有表A和表B,并且我有从表A开始到表B结束的数据,并且我有一个表C,它有一个指向A主键的外键,但是当数据从A中删除并最终到达表B时,它应该指向B(与A的数据具有相同的id)。这会引起混乱吗。这里有一个例子来说明我的意思:
A(待定结果)
id=3
B(完成结果)
无效的
C(用户)
id=1
结果id=3(A和B的外键)
三分钟后,结果已经公布。
A(待定结果)
无效的
B(完成结果)
id=3
C(用户)
id=1
结果id=3(A和B的外键)
这个实现有什么问题吗。还是把A和B放在一张桌子上比较好?我担心的是桌子会变大。作为单独的表,对表A的读取将远远大于对表B的读取,而对表A的读取将小得多,因为它只是等待结果。如果将A和B合并到一个表中,那么它将同时是待处理结果和所有已完成结果的历史记录,因此查找待处理结果将花费更多的时间。所有这些都是postgresql做的,如果这有区别的话。
所以我想我的问题是:这个实现是否适合中等规模的应用,或者考虑到我刚才所说的信息,我是否应该将表a和表B组合起来(即使B将无限大地增长,而a只包含当前的数据,并且显著地变小)。
最佳答案
听起来你已经发现这不起作用了。我不能很好地学习你的榜样,因为“A”、“B”和“C”从来都不适合我我怀疑那些公式化的标签对其他人来说比细节更好。你就是赢不了;—)不管怎样,听起来你面临的是一个实际的问题,表的大小,并试图使用一个设计,分裂成两部分自然表。(又热又旧)正如你所发现的,这对系统中的钥匙并不起作用。关系模型(等等)没有“这个东西是这个或那个的孩子”的概念,所以,你在往上游游。不管怎样,这种设置在野外非常普遍,以至于有了名字。好吧,好几个名字。”BillKarwin的SQL反模式中的“多态关联”很常见。顺便说一句,那是本好书,而且很短。同样,“滥交”这个词你也会看到。或者有时您会看到表本身被列为“跳转表”或“集线器”等。
我怀疑这一非关系模式被如此广泛地使用是有原因的:它对人类来说是有意义的。一个关系模型总是紧绷的领域是当你拥有某种东西的时候。比如,员工或学生。有这么多共同的领域,有几个是不同于他们的特定类型。一张桌子?两个?三个?Postgres中的表继承可能有帮助……至少它正在尝试。无论如何,多态关系在RDBMS中是有问题的,因为它们不能被自动建模或约束。您需要自定义代码来确定此记录是该表或另一个表的子表。你不能把这件事扯到关系上。如果你对这个设计问题的各种解决方案感兴趣的话,Karwin的章节非常好,容易阅读,并且充满了可供选择的设计。如果你不想追踪这本书,但有点感兴趣,请看几年前的这篇文章:
https://hashrocket.com/blog/posts/modeling-polymorphic-associations-in-a-relational-database
很有可能,你现在的兴趣越来越浓厚了。听起来你有一个处理管道,里面有一些活动的记录,还有越来越多的旧记录。你没有提到你的Postgres版本,但你可能比你想象的要少担心。首先,可以考虑对表进行分区。分区表有一个单独的逻辑表,您可以在查询中使用一组较小的物理表进行对话。您可以直接访问分区,但不需要。你只要和我的大桌子谈谈,博士后就知道去哪里找。所以,你可以将数据按周、月等进行拆分,这样就不会有一个桶对你来说太大了。在这种情况下,各个分区也有自己的索引。所以,最终会得到更小的表和更小的索引。为此,你最好使用第11页,或者也许是第10页。分区是一个很大的主题,Postgres特性集并不是适合每种情况的完美匹配……您必须在它的限制范围内工作。我现在就不说了,因为这可能不是你首先需要的。
比分区更简单的是一个你可能不知道的很棒的Postgres特性,部分索引。这并不是Postgres所独有的(SQL Server将同一类特性称为“过滤”索引),但我认为MySQL没有。好吧,这个想法非常简单:构建一个索引,它只包含与条件匹配的行。下面是一个例子:
CREATE INDEX tasks_pending
ON tasks (status)
WHERE status = 'Pending'
关于postgresql - 两个表的一个外键会引起混淆吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56762872/
我正在尝试从par_iter()内部捕捉到 panic ,并继续执行par_iter块之后的操作。 如果我有这个,我会正确地获得一切,并且不会出现 panic : let dog: Dog = Dog
我可以假设从 JDK 类加载机制抛出的每个 NoClassDefFoundError 总是在堆栈跟踪中将 ClassNotFoundException 作为原因吗? 另外,NoClassDefFoun
我有下面的程序 package com; import java.io.PrintStream; import java.net.URL; import java.net.UR
我有一些由另一组人编写的简单代码(目前不可用),它引用了我得到的一些 jar 文件。当我编译代码时,一切都构建得很好,但是一旦代码尝试创建在其中一个 jar 文件中定义的类的实例,我就会收到 java
我正在尝试按照 https://github.com/airbrake/airbrake-django#manually-sending-errors-to-airbrake 上的示例进行操作手动向
我不确定为什么这是递归的。 jTable1.getModel().addTableModelListener(new TableModelListener() { public void table
我按照 https://github.com/cloudfoundry/vcap 上的自述文件进行操作 它应该工作正常... 但我得到了这样的错误: 有谁知道发生了什么? 我在 Ubuntu10.04
我只是想知道当你有 UI-Router 的空白页面时,有人知道如何调试情况。 (当然,控制台没有任何错误) 通过为路由器事件执行 console.log(取自 here),我发现它进入了正确的状态,但
我们的网站上有一个问题,一些 Firefox 用户在访问我们的网站时会收到“错误请求”消息(仅此而已,只是“错误请求”字样!) 这似乎是由于 google 跟踪 cookie 损坏,可能是 __utm
在使用guard-rspec在Rails 4项目中运行guard时,在vim中打开/关闭文件时偶尔会看到以下错误。我试过升级/降级guard,guard-rspec,pry和其他没有运气的库。 rub
今天我在编写程序时遇到了这个错误。 Caused by:java.lang.ClassCastException: org.cubeville.blocks.CrossedBlockBrush can
我在执行应用程序时遇到空指针异常,但我不确定原因。问题发生在线路上: task.execute(""); 但我不确定为什么会出现空指针异常。 (我已经验证我有互联网连接,并且它所连接的 XML
嗨,我有一个 java 应用程序,我正在尝试使用它写入 tempDir,但我仍然遇到以下异常。我承认我对编写文件不太了解,所以希望我缺少一些小东西。 Caused by: java.io.FileNo
我不明白为什么会发生这种情况。我对其他问题做了一些研究,发现使用 for 循环时无法修改集合。但是,我正在使用迭代器,为什么它不起作用? int counter = 0; int otherC
目前我正在使用 OSX Server (Yosemite) 来托管一堆 PHP 应用程序,其中一些应用程序在网站文档根目录下有一个子目录用于子域。自更新到 Yosemite 版本的 OSX Serve
SqlCommand objsql = new SqlCommand(); . . objsql.Parameters.AddWithValue("@Param1", DBNull.Value); .
当我尝试将“对象”添加到数据库然后将其显示到 TableView 时,它显示 UnsupportedOperationException 。一切都很好,直到我将此代码添加到“public void i
我收到以下错误日志: 05-29 20:57:29.886: D/AndroidRuntime(359): Shutting down VM 05-29 20:57:29.896: W/dalvikv
我有两个项目,第一个是Ejb3项目,名称是SessionBean,另一个是java项目,名称是SessionBeanClient。对于 IDE,我使用 eclipse indigo。我已经完成了代码,
我有一个使用表单成员身份验证的 ASP.NET Web 应用程序。我们最近进行了渗透测试,标记的一个问题是窃取用户帐户的能力。如果 .ASPXAUTH cookie 值是在注销之前从用户复制的,用户可
我是一名优秀的程序员,十分优秀!