- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在阅读 EAV database大多数缺点似乎是与非常非常糟糕的 EAV 设计或困难相关 generating reports from the data .
通常当您看到人们提示 EAV 时,他们使用少于三个表来尝试复制 RDBMS 中单独表 + 列的功能。有时这意味着将所有内容从小数到字符串存储在单个 TEXT
值列中。 EAV 还会破坏数据完整性的安全防护,如果您不小心,这可能会非常糟糕。
但是,EAV 确实提供了一种简单的方法来跟踪历史数据,并允许我们在 SQL 和键值存储系统之间来回移动系统的各个部分。
如果我们根据类型分离不同的实体属性会怎么样。这将使我们仍然可以处理belongsTo、Has、HasMany 和 HasManyThrough 关系,以及与特定属性和实体关联的正确索引值。
考虑以下两个基本实体
products (price -> decimal, title -> string, desc -> text, etc...)
attributes
options
[...]
int
datetime
string
text
decimal
relation
[id,foreign_key]
users (gender -> options, age -> int, username -> string, etc...)
attributes
options
[...]
int
datetime
string
text
decimal
relation
[id,foreign_key]
众所周知,用户资料和产品是世界上最多样化的项目之一。每个公司以不同的方式处理它们,并根据他们的需要使用不同的“列”或“属性”。
以下是如何处理多个(嵌套和/或关系)实体的 View 。
想法是每个实体都有这个主属性表,然后指定如何查找和解释这些值。这使我们能够处理特殊情况,例如其他实体的外键以及“选项”或十进制数字等。
实体类型{ ID, 类型,//即“博客”、“用户”、“产品”等。 创建时间
entity {
id,
entity_type_id,
created_at
}
attr {
id,
entity_id,
type,
name,
created_at
}
option {
id,
attr_id,
entity_id,
multiple, // multiple values allowed?
name,
created_at
}
attr_option {
id
attr_id,
entity_id,
option_id
option,
created_at
}
attr_int {
attr_id,
entity_id,
int,
created_at
}
attr_relation {
attr_id,
entity_id,
entity_fk_id,
created_at
}
attr_datetime {
attr_id,
entity_id,
datetime,
created_at
}
attr_string {
attr_id,
entity_id,
var_char,
created_at
}
attr_text {
attr_id,
entity_id,
text,
created_at
}
attr_decimal {
attr_id,
entity_id,
decimal,
created_at
}
这样的表将允许我们永远不必 UPDATE ...
因为我们可以为每个更改值并添加的新属性 INSERT INTO ...
created_at
以了解最新值是什么。这非常适合保存历史数据记录(当然仍然可以异常(exception))。
首先,它是什么“类型”的实体? (用户、帖子、评论等。)
SELECT * FROM entity_type et LEFT JOIN entity e ON e.entity_type_id = et.id WHERE e.id = ?
接下来,这个实体的属性是什么? (表属性)
SELECT * FROM attr WHERE entity_id = ?
接下来,该实体的属性中存在哪些值? (attr_### 表)
SELECT * FROM attr_option, attr_int, attr_relation, attr_text, ... WHERE entity_id = ?
vs
SELECT * FROM attr_option WHERE entity_id = ? if( ! multiple) ORDER BY created_at DESC LIMIT 1
SELECT * FROM attr_int WHERE entity_id = ? ORDER BY created_at DESC LIMIT 1
SELECT * FROM attr_relation WHERE entity_id = ? ORDER BY created_at DESC LIMIT 1
SELECT * FROM attr_text WHERE entity_id = ? ORDER BY created_at DESC LIMIT 1
...
这个实体存在什么关系?
假设我们有一个 ID 为 34 的“帖子”实体,并且我们想要它的“评论”(entity_type = 2),这可以让我们获取产品实体的评论实体 ID:
SELECT * FROM entity AS e
LEFT JOIN attr_relation AS ar ON ar.entity_id = e.id
WHERE ar.entity_id = 34 AND e.entity_type = 2;
除了多个查询(键值存储无论如何都需要),这种方法会存在什么问题?
最佳答案
EAV“数据库”[原文如此]是字面上 数学上 直接数据库及其元数据三元组的无证描述,没有列出关系、查询关系、查询元数据、类型检查、维护完整性、优化、原子处理或控制并发的功能。
软件工程原则规定,合理的 EAV 数据库 [sic] 使用完全包括定义适当的抽象(类型、运算符、过程、解释器、模块)重构 DBMS 的功能。
从一个人的 EAV 三元组及其含义到(碎片化的)数据库描述的映射的机械性质使得这一点很容易显示。
释义Greenspun ,任何足够复杂的 EAV 项目都包含一个临时的、非正式指定的、错误缠身的、缓慢的 DBMS 一半的实现。
我再说一遍:EAV 是对数据库及其元数据的三元组的未记录描述,没有 DBMS。仅对您已证明 DDL 解决方案无法满足性能要求而 EAV 解决方案可以而且值得的数据库部分使用 EAV。
关于sql - 为历史数据正确设计 EAV 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21714715/
假设我有一个具有许多属性的实体,其中一些我现在知道,而另一些将由用户定义。对此建模的最佳方式是什么? 1) 我是否有主表并将其关联到辅助名称-值对表?所有属性都在辅助 EAV 表中。 或- 2) 我是
我理解EAV中的三个基本故障,即重新组装数据需要大量工作。但是,我想要一个可以添加自定义字段的数据库。很多人说Virtuemart允许自定义字段,但不使用 EAV 数据库结构。有人可以解释如何做到这一
如果我的应用程序需要能够根据用户输入更改 db 架构,我正在尝试决定该走哪条路。 例如,如果我有一个包含汽车属性(如年份、型号、门数量等)的“汽车”对象,我该如何将它存储在数据库中,以便用户能够添加新
Magento 中的所有表格都遵循 EAV 设计吗? 在哪里可以找到有关表的信息,我的意思是每个表的用途以及它存储的内容等? 有什么建议吗? 最佳答案 名称中包含 flat 的所有表都设置为标准关系数
其他人如何使用关系建模工具将逻辑模型或第三范式映射到使用 EAV 的数据库? 最佳答案 EAV 是一种非关系型设计。您无法使用 EAV 实现任何范式,因为它不是关系。 EAV 是 Inner-Plat
我正在使用 PHP 和 PostgreSQL 重建应用程序(这里是独立开发人员)。对于大多数数据,我使用一个表来存储它,每个属性都有多个列。但是,我现在开始为内容存储构建一些表。在这种情况下,内容是多
我正在开发一个小型内容管理系统,其中的数据关系密切。我从一个小的抽象开始,但我可能会选择一个完整的实体属性值模型。然而,我突然想到,我正在关系数据库(pgsql)上构建所有这些,并且在这样强大的引擎之
我们将在场景中使用 EAV 模式,其中我们将拥有具有截然不同属性的各种不同实体。 “基本”EAV 模式由 3 个表组成。由于不同的属性有不同的数据类型(日期、长整型、 bool 型……),我目前正在考
我有下表在 EAV 模型中存储数据: +-------------+---------+------+-----+---------+-------+ | Field | Type
我的 Mysql 数据库具有由对象类型定义的对象,然后连接该对象类型以设置其属性。它基于 Spencer 指出的实体属性值模型。 数据库比下面的要复杂一些,但这应该使我的问题更清楚一些。 我有一个 m
我正在制作一个应用程序,除其他外,还有一个用户信息管理部分。用户注册时需要填写 10 个基本字段(名字、姓氏、地址等),但管理员还可以定义将包含在注册表中的自定义字段。目前我用 EAV 实现了它。我有
我在查看使用 EAV 设计的数据库时感到困惑概念。 EAV代表实体、属性和值。我的问题是:EAV 数据模型是否被视为数据库规范化的高级形式?它是“必须使用”才能“保持最新”吗? 长话短说:何时使用 E
假设我有下表: TABLE: one =============================== | id | first_name | last_name | =================
我有一个包含超过 100K 条记录的数据库。很多类别和很多项目(每个类别具有不同的属性)一切都存储在 EAV 中。 如果我尝试打破这个方案并为任何类别创建一个唯一的表格是我必须避免的事情吗? 是的,我
简介 我一直在阅读 EAV database大多数缺点似乎是与非常非常糟糕的 EAV 设计或困难相关 generating reports from the data . 通常当您看到人们提示 EAV
我的数据库结构如下,实现了一个简单的 EAV 模型(见图): 我的产品有一个类型,它通过联结表限制prop_names,可用于该产品。这里一切都很清楚。但:然后我添加了一个 prop_values 表
我正在尝试在 Magento 1.7.0.0 中设置自定义实体,遵循 alan storms article about it ,但是使用这个简单的安装脚本,它告诉我“无法创建表:eavblog_po
鉴于用户必须能够在一个对象上定义他们自己的字段,并为这些字段定义允许的值 - 动态(无编译) - 你将如何在不使用 EAV 的情况下解决这个问题? 示例:所有对象都需要对 123 状态编号进行一次或多
我已经搜索过此内容,并尝试在过去几天内自行制作,但我做不到。我在搜索中得到的最接近的答案是这个答案,也在Stack Overflow上:EAV Select query from spreaded v
我想根据存储在数据库中的动态参数创建表单。 所以我创建了一个名为 Parameter 的实体,它定义了参数名称,它应该显示为表单字段标签。 /** * @ORM\Entity */ class P
我是一名优秀的程序员,十分优秀!