可以肯定地说EAV/CR数据库模型很糟糕。也就是说,
问题:应该使用什么数据库模型、技术或模式来处理描述电子商务产品的属性“类”,这些属性可以在运行时更改?
在一个好的电子商务数据库中,您将存储选项类别(例如电视分辨率,然后为每台电视提供一个分辨率,但下一个产品可能不是电视,也没有“电视分辨率”)。您如何存储它们、有效搜索并允许您的用户使用描述其产品的可变字段设置产品类型?如果搜索引擎发现客户通常根据控制台深度搜索电视,您可以将控制台深度添加到您的字段中,然后在运行时为每个电视产品类型添加单个深度。
优秀的电子商务应用程序有一个很好的共同特征,它们显示一组产品,然后有“向下钻取”侧菜单,您可以在其中看到“电视分辨率”作为标题,以及最常见的前五个电视分辨率发现集。您单击一个,它只显示该分辨率的电视,允许您通过选择侧面菜单上的其他类别进一步深入研究。这些选项将是在运行时添加的动态产品属性。
进一步讨论:
长话短说,互联网上是否有任何链接或模型描述可以“从学术上”解决以下设置? 我感谢 Noel Kennedy 提出了一个类别表,但需求可能不止于此。我在下面用不同的方式描述它,试图突出它的重要性。我可能需要进行视点校正来解决问题,或者我可能需要更深入地了解 EAV/CR。
喜欢对 EAV/CR 模型的积极响应。我的开发人员同事都说 Jeffrey Kemp 在下面谈到的内容:“新实体必须由专业人士建模和设计”(断章取意,请阅读下面的回复)。问题是:
- 实体每周添加和删除属性
(搜索关键字决定未来的属性) - 每周都有新实体到货
(产品由零件组装而成) - 旧实体每周消失
(存档、不太受欢迎、季节性)
客户想要为产品添加属性有两个原因:
- 部门/关键词搜索/同类产品对比图
- 结账前的消费产品配置
属性必须有意义,而不仅仅是关键字搜索。如果他们想比较所有有“奶油糖霜”的蛋糕,他们可以点击蛋糕,点击生日主题,点击奶油糖霜,然后检查所有有趣的蛋糕,知道它们都有奶油糖霜。这不是特定于蛋糕的,只是一个例子。