我一直在尝试为在线应用程序的自定义字段回答一个复杂的 Mysql 数据结构问题。我对 Mysql 还很陌生,所以任何输入都会受到赞赏。
当前数据库是关系数据库,服务的每个用户将共享相同的数据库和表。
这是我正在尝试做的一个例子。
假设我正在尝试创建一个列表。此列表最多可包含 30 个自定义字段。用户可以在 12 个唯一元素之间进行选择,每个元素最多可以有 15 个用户定义的属性。
每个列表在帐户内以及帐户之间都可以是唯一的。帐户可以有许多列表,每个列表可以有不同数量的元素以及每个元素的不同属性。
一个元素可以是很多东西,例如:多项选择、单选按钮、电话字段、地址、单行文本、多行文本等。
多选(复选框)元素的属性示例可以是:红色、绿色、蓝色、橙色、白色、黑色
单行文本元素的示例可能是: 名字输入字段。
每个元素还必须有一个用户定义的标题字段和标签字段,可以在应用程序的其他功能中引用和使用。
细分也很重要。用户需要能够根据任何元素对列表进行分段。例如,用户可能希望根据多项选择元素#1 中存在“红色”的所有记录来对列表“ABC”进行分段(他们可能有超过 1 个用于列表的多项选择元素)。
在此示例中,我假设数组、EAV、序列化 LOB 可以正常工作。但是,我不确定在我的规模上什么是最适合我需求的结构。
实际上,每个列表很可能有多达 50,000 条记录,并且确实有可能有 20,000 多个帐户 - 每个帐户都有许多列表。因此,我正在寻找最有效和最灵活的结构。
为了使事情变得更加复杂,我还需要确保在任何给定时间向任何特定列表添加/删除元素的有效方法。例如,如果用户创建了一个包含最大允许数量的自定义字段 (30) 的列表,然后三个月后决定他们要删除一个字段,我需要一种方法来查找该列表以及该自定义字段的所有关联值,并且然后删除所有值、元素类型及其属性。然后将允许用户向该列表添加新元素。
我已经查看了该站点上的许多 EAV 帖子,以及这个http://www.martinfowler.com/eaaCatalog/serializedLOB.html由于数据,EAV 似乎对我的需求不是很有效检索的缺点。
我还想知道多维数组在这种规模下的工作情况如何?我相信 wordpress 将其用于他们的自定义字段。
对于如何最好地为这种情况构建数据库的任何输入将不胜感激。谢谢!