- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对数据库中的整个数据实现父类(super class)型和子类型是否不好?在转向这个方向之前,我需要一些建议......
例如,
我将这些表作为对象,并且它们是相关的,
users
pages
images
entities
表作为父类(super class)型
entity_id entity_type
1 page
2 page
3 user
4 user
5 image
6 image
用户
表
user_id entity_id
1 3
2 4
页面
表格
page_id entity_id
1 1
2 2
图像
表
image_id entity_id
1 5
2 6
这是将images
表与entities
表映射的表,因为某些图像属于特定页面(可能是博客文章等) future ),
map_entity_image
表
entity_id image_id
1 1
1 2
因此,当我要创建页面、图像、用户等时,我将在 entities
表中插入一行。
最终,该表中的行数将会大量增加。所以我担心它能处理大量的行吗?随着时间的推移,这个数据库会变得越来越慢吗?
毕竟,这些结构是不是很糟糕?
或者也许我错误地执行了父类(super class)型/子类型?
编辑:
我认为实体
应该只包含这些数据,
entity_id entity_type
1 page
2 page
除非我想将图像附加到用户等,那么它应该是这样的,
entity_id entity_type
1 page
2 page
3 user
4 user
也许我错了...
编辑:
所以这是我如何找出页面 id 1 附加了多少图像的查询,
SELECT E.*, P.*, X.*,C.*
FROM entities E
LEFT JOIN pages P ON (P.entity_id = E.entity_id)
LEFT JOIN map_entities_images X ON (X.entity_id = E.entity_id)
LEFT JOIN images C ON (C.image_id = X.image_id)
WHERE P.page_id = 1
返回2张图片。
最佳答案
如果您需要的只是将图像附加到用户和页面,我不确定完整的类别(又名“子类”、“子类型”、“继承”)层次结构是否是最佳选择。
假设页面/用户可以有多个图像,并且任何给定的图像都可以附加到多个页面/用户,并且假设您不想将图像附加到图像,您的模型可能应如下所示:
<小时/>
您可以使用类别层次结构来实现类似的结果...
...但是由于子类太少,我建议不要使用它(由于潜在的可维护性和性能问题)。另一方面,如果将来有可能添加新的子类,这实际上可能是正确的解决方案(ENTITY_IMAGE 将自动“覆盖”所有这些新子类,因此您不需要引入新的“链接”每一个表)。
顺便说一句,有3 major ways实现类别层次结构,每个类别都有自己的一组权衡。
关于mysql - 父类(super class)型和子类型的含义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9423872/
这个问题在这里已经有了答案: Towards the "true" definition of JAVA_HOME (5 个答案) 关闭 4 年前。 为什么 ActiveMQ 提供者需要设置 JAV
这个问题在这里已经有了答案: What is a lambda expression in C++11? (10 个答案) 关闭 8 年前。 这是来自 boosts asio 的一个例子。这是什么意
这个问题在这里已经有了答案: What does the double colon (::) mean in CSS? (3 个答案) 关闭 7 年前。 我经常看到这种用法。特别是伪类。“::”在
嗨,另一个愚蠢的简单问题。我注意到在Apple框架中的某些typedef中使用符号"<<"谁能告诉我这是什么意思?: enum { UIViewAutoresizingNone
someObject.$() 是什么意思? 我正在浏览 sapui5 工具包中的 tilecontainer-dbg 文件,发现了这个: var oDomRef = this.$(); or some
这个问题已经有答案了: How to interpret function parameters in software and language documentation? (4 个回答) 已关闭
我遇到过这个语法。任何人都可以解释一下 getArg1ListInfo:()=>(object.freeze(arg1)) 的含义 function foo (arg1,arg2) { let
对于子类,我有以下代码: class child1 : public parent { public: static parent* function1(void) { ret
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 1 年前。 我有一部分代码包含以下功能: void Keyb
以下在 C++ 中是什么意思? typedef PComplex RComplex [100]; 请注意,PComplex 是我代码中的用户定义类型。 谢谢 最佳答案 RComplex 是 PComp
在我的 Lisp 代码中,我有函数 (nfa-regex-compile),它创建一个包含初始状态、转换和最终状态的 cons 列表(表示自动机的节点)从作为参数给出的正则表达式开始。 在这种情况下,
以下文字摘自 Learning Spark 第 3 章 One issue to watch out for when passing functions is inadvertently seria
PHP 文档 block 中以下内容的含义是什么: #@+ zend框架代码中的一个例子: /**#@+ * @const string Version constant numbers */ c
由于 python 的一些版本控制问题,我必须使用自定义函数来比较 HMAC (SHA512)。为此,我找到了这个函数: def compare_digest(x, y): if not (i
取自this answer here : static const qi::rule node = '{' >> *node >> '}' | +~qi::char_("{}"); 请注意,声明了名称
我正在查看 chi 包的文档。我看到类似的东西: https://github.com/pressly/chi/blob/master/_examples/rest/main.go#L154 data
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
我想知道如果我采用值为 8 的 INT,这是否意味着我只能从 1 到 99999999 或从 1 到 4294967295 UNSIGNED? 最佳答案 文档似乎很清楚这一点: Numeric Typ
这个问题在这里已经有了答案: 关闭9年前。 Possible Duplicate: Does “/* (non-javadoc)” have a well-understood meaning? 以下
在 Prolog 代码中,可以使用“ headless ”Horn 子句将指令传递给编译器,这些子句与指向左侧的物质蕴涵 ':-' (⇐) 的左侧没有头部关系。例如,导入模块或声明 Unit Test
我是一名优秀的程序员,十分优秀!