- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在构建一个严重依赖 EAV pattern 的网络应用程序。用于存储数据。这基本上意味着对象的每个属性在庞大的数据库表中都有自己的行。我正在使用 MySQL 来存储所有内容。这是我正在存储的内容的一个非常简化的示例...
OBJECTS ATTRIBUTES
objId | type objId | attribute | value
============= =========================
1 | fruit 1 | color | green
2 | fruit 1 | shape | round
3 | book 2 | color | red
我知道有些人讨厌 EAV,但我需要能够在不修改数据库架构的情况下任意添加新的对象属性,并且到目前为止它对我来说效果很好。
我认为其他人在使用 EAV 数据结构构建系统时会发现,这种方法的弱点是检索多个对象以及每个对象的属性。目前我的应用程序一次只显示 10 个对象,所以我只查询我的 EAV 表 10 次(每个对象一次),它仍然非常快。但是,我想消除这个限制并允许一次性获取数百个对象。我还希望能够以比目前更灵活的方式查询对象。
使用 SQL 连接执行此操作会很糟糕,因此我正在考虑缓存数据。平均而言,每 1 次写入,数据库会获得大约 300 次读取,所以我认为这是一个很好的缓存候选者。
到目前为止,这些是我想出的选项...
XML 数据库列: 每次执行写入时,更新 objects 表中包含所有对象属性的 XML 文本列。这将有助于快速读取数据,但查询隐藏在数据库表中的 XML 数据会很麻烦。
XML 文件: 每次执行写入时,将一个 XML 文件写入磁盘,其中包含每个对象及其属性。这样做的好处是我可以使用 XQuery 来查询对象。
NoSQL(例如 MongoDB):也许我应该在 MongoDB 这样的无模式数据库上构建系统。重新编写整个应用程序以使用 MongoDB 会非常耗时,但让我感到震惊的是,我可以将它用作缓存。例如,每次将数据写入 EAV 存储时,MongoDB 中的等效对象都会更新,然后用于读取和查询。
最初我认为 XML 文件是最好的方法,但我发现文件变得非常大且难以管理。目前我倾向于使用 MongoDB。我知道为一个应用程序运行两个数据库服务器似乎很疯狂,但我认为它可以在我的情况下工作。
我很想听听您对此的看法。
最佳答案
我只看到两种方式,评论中都提到了这两种方式。
首先,您可以真正迁移到像 Mongo 这样的面向文档的数据库 - 这适合作为 EAV 的替代品。因为它不会是 JOIN 和其他逻辑,所以它会非常快并且略微缩放。 (所以,也许您可以避免使用缓存)。
其次,您可以使用特定的缓存工具,如 Redis 或 Mongo 或 Memcached 将每个查询结果保存一段时间。
但我想把注意力转向这个系统的 future 。什么是计划加载和缩放?如果要减少系统负载,我认为最好的方法是迁移到面向文档的数据库。或者,如果您想立即获得结果(缓存数据以供读取) - 可以通过使用缓存工具来实现,即使 [如果可能] 在网络级别(例如 nginx 支持开箱即用的 memcached)。
因此,像往常一样,您应该在一次性成本和持续成本之间找到平衡。
关于mongodb - 缓存 EAV 数据 - XML 或 NoSQL/MongoDB?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9000546/
假设我有一个具有许多属性的实体,其中一些我现在知道,而另一些将由用户定义。对此建模的最佳方式是什么? 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
我是一名优秀的程序员,十分优秀!