mysql - 自定义字段的数组、EAV、序列化 LOB?

标签 mysql field entity-attribute-value schemaless

我一直在尝试为在线应用程序的自定义字段回答一个复杂的 Mysql 数据结构问题。我是 Mysql 的新手,所以欢迎任何意见。

当前数据库是关系型数据库,服务的每个用户将共享相同的数据库和表。

这是我正在尝试做的一个例子。

假设我正在尝试创建一个列表。此列表最多可包含 30 个自定义字段。用户可以在 12 个唯一元素之间进行选择,每个元素最多可以有 15 个用户定义的属性。

每个列表在一个帐户内以及帐户之间都可以是唯一的。帐户可以有多个列表,每个列表可以有不同数量的元素以及每个元素的不同属性。

一个元素可以是很多东西,例如:多选、单选按钮、电话字段、地址、单行文本、多行文本等。

多选(复选框)元素的属性示例可以是:红色、绿色、蓝色、橙色、白色、黑色

单行文本元素的示例可以是:名字输入字段。

每个元素还必须有一个用户定义的标题字段和标签字段,可以在应用程序的其他功能中引用和使用。

分段也很重要。用户需要能够根据任何元素对列表进行分割。例如,用户可能希望根据多项选择元素 #1 中存在“红色”的所有记录来分割列表“ABC”(他们可能有一个列表的多个多项选择元素)。

在此示例中,我假设数组、EAV、序列化 LOB 可以正常工作。但是,我不确定在我的规模下什么是满足我需求的最佳结构。

实际上,每个列表很可能有多达 50,000 条记录,而且确实有可能有 20,000 多个帐户 - 每个帐户都有大量列表。因此,我正在寻找最高效、最灵活的结构。

为了使事情变得更加复杂,我还需要确保在任何给定时间以一种有效的方式向任何特定列表添加/删除元素。例如,如果用户创建了一个包含最大允许自定义字段数 (30) 的列表,然后三个月后他们决定删除一个字段,我需要一种方法来查找该列表以及该自定义字段的所有关联值,并且然后删除所有值、元素类型及其属性。然后将允许用户向该列表添加新元素。

我已经查看了本网站上的许多 EAV 帖子,以及这个 http://www.martinfowler.com/eaaCatalog/serializedLOB.html由于数据检索的缺点,EAV 似乎不能非常有效地满足我的需求。

我还想知道多维数组在这种规模下的表现如何?我相信 wordpress 将其用于他们的自定义字段。

对于如何最好地为这种情况构建数据库,我们将不胜感激。谢谢!

最佳答案

您可以阅读 FriendFeed 如何实现自定义字段: http://bret.appspot.com/entry/how-friendfeed-uses-mysql

他们使用序列化 LOB 的组合,以及包含倒排索引的额外表。您不需要为 LOB 中的每个可能属性创建一个额外的表,只需要在索引的帮助下搜索您想要搜索的属性。

关于mysql - 自定义字段的数组、EAV、序列化 LOB?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3909316/

相关文章:

php - 如何在选择中嵌入选择或从选择中调用另一个函数?

field - Field SenchaTouch 上的只读属性

database - 通用数据库表

Magento:为所有产品添加新属性

Java 两个字段之间的关系

php - 我应该在 Laravel 中使用 EAV 模型吗?

mysql - 寻求帮助了解 Mongo DB 数据组织

mysql - 需要两个限制?

php - 如何合并数据库中的数组数据

drupal - 以编程方式创建 Drupal 7 字段组