核心数据相同实体的多个实例 - 共享属性的实体

时间:2015-05-21 06:44:50

标签: ios entity-framework core-data database-design data-modeling

我试图围绕如何拥有相同Core Data实体的多个实例。这似乎不可能,所以我必须接近这个错误。

基本上,我说有一个可以装满多个气球的购物车。但每个气球可以有不同的颜色。如果我编辑气球的模板,则所有气球都将更新以反映更改。所以说我将模板名称改为'培根',所有气球的名字都会变成'培根'同样。

如何使用Core Data实现这一目标?

修改

根据要求,我会尝试澄清我想要做的事情。

也许这个例子会更清楚。

假设您正在为练习创建模型。所以你有Ab RollerShoulder Press

workout中,您可能有多个实例。所以在一个workout中你会有,比如说

  1. Ab Roller
  2. Shoulder Press
  3. Ab Roller
  4. Ab Roller的每个实例都与Sets有自己的关系,当然每个实例都会有所不同。

    也许不是最好的例子,但应该更清楚地理解重复实例。

    我在考虑拥有一个template实体,然后是一个instance实体,以及它们之间的关系 - 当template实体name更新时,所有{{ 1}}实体instance通过KVO更新。或者我将所有共享属性(即name)放在关系中(因此name实体的instance属性会返回其name' s { {1}}属性),以便它们反映template的更改。最好的方法是什么?

1 个答案:

答案 0 :(得分:1)

我将从数据库设计的角度来回答这个问题,因为评论中的一致意见认为这更像是一个通用的数据库设计问题。如果这不能解决您的所有问题,那么希望知道核心数据来龙去脉的人可以为您清除这方面的内容。

您正在考虑为系统保留一些配置数据,然后还保留使用该配置数据的各种实体实例的数据。您已经提出了一个模板实体(我也看到这个称为定义或配置实体)和实例实体的一般模式肯定是我之前遇到过的,我没有看到问题那个。

数据库规范化规则告诉您避免在数据库中进行数据复制。因此,如果您的模板实体具有名称字段,并且每个实例实体应具有相同的名称,那么您应该将该名称保留在模板实体中,并通过外键引用该实体。否则,当名称发生更改时,您必须更新实例表中的每一行以匹配 - 这将是一项昂贵的操作。或者更糟糕的是,它不会得到更新,您最终会在系统中输入不匹配的数据 - 这被称为update anomaly

因此,想出购物车和某种电子商务解决方案的存货(就像你的第一个例子一样),你可能有一个BasketItem实体和一个ItemTemplate实体:

ItemTemplate:  
* ItemTemplateId  
* Name  

BasketItem:  
* BasketItemId  
* ItemTemplateId  
* Color

然后您的气球模板数据和气球实例的数据在数据库中将如下所示:

ItemTemplate:

| ItemTemplateId | Name    |  
| 7              | Balloon |  

BasketItem:

| BasketItemId | ItemTemplateId | Color   |  
| 582          | 7              | Blue    |  
| 583          | 7              | Green   |

(这显然是大规模简化的,只是看一个具体的例子而忽略了篮子和物品的所有机制,所以不要把它作为实际的设计建议。)

此外,您可能希望保留更多配置数据,这可能会彻底改变设计:例如,您可能希望保留有关不同产品的可用颜色的配置数据。上面使用的相同概念适用于其他地方 - 如果你意识到你一遍又一遍地持有“蓝色”,并意识到你将来可能想要将其改为“深蓝色”,因为你现在存有多种色调的蓝色气球,那么它是有道理的将颜色只存储一次,然后将一个外键指向存储的任何位置,这样你就不会对整个BasketItem表进行大量更新,将每个“蓝色”实例更新为“深蓝色”。 “

我强烈建议您阅读有关数据库设计和数据库规范化的一些内容。它将帮助回答您在这些方面遇到的任何问题。您可能会发现在某些情况下您需要违反规范化规则 - 可能是为了使ORM工具优雅地工作,或者出于性能原因 - 但是以更明智的方式做出这些决策会更好,知道您可能会导致什么问题,采取进一步措施防止它们发生。