gpt4 book ai didi

ios - 如何强制单向对多关系持续存在

转载 作者:行者123 更新时间:2023-12-01 15:45:22 27 4
gpt4 key购买 nike

当一对多关系没有反向时,核心数据就会出现问题。对相关属性所做的更改不会保留。这是我们许多人都遇到过的问题,因为它可以通过谷歌搜索找到。

这是想问你们中是否有人找到了实现持久性的技巧/解决方法,除了明显的答案或添加反向关系。

背景:

  • 即使文档中不鼓励单向关系,也不禁止它们。该文档仅坚持在没有逆时产生的责任。
  • 核心数据文档中概述了不需要逆关系的原因:当您将大量项目链接到一个实体时,逆关系会在每次添加项目时加载一个大型 NSSet。消耗内存,可能无缘无故超出允许范围。

示例

在员工/部门的典型范例中,如果您有大量员工可以属于多个部门,则您需要从员工到部门的一对多关系。您想要反过来,因为每次将员工链接到部门时,都必须加载、更新和保存(非常)大的 NSSet。此外,如果部门实体从未被删除,则图的完整性很容易维护。

请不要回复说这是core-data的特性,逆向关系是必须的。这不是这样说明的,更像是一个错误而不是一个功能。发布错误报告并不能解决当前已部署系统的问题。

编辑:加入实体解决方案此编辑是为了对 Dan Shelly 在下面的回答建议进行更多阐述和讨论。

首先,要回答您的第一个问题,我不是要多对多,而是真正的单向多对多。您链接的同一页面的文本位于您引用的页面下方:

Unidirectional Relationships

It is not strictly necessary to model a relationship in both directions. In some cases it may be useful not to, for example when a to-many relationship may have a very large number of destination objects and you are rarely likely to traverse the relationship (you may want to ensure that you do not unnecessarily fault in a large number of objects at the destination of a relationship). Not modeling a relationship in both directions, however, imposes on you a great number of responsibilities, to ensure the consistency of the object graph, for change tracking, and for undo management.

也就是说,如果没有强制核心数据自动生成和更新它的解决方案,您提出的添加连接实体的解决方案是一种可行的方法。

IMO,对于我的用例,加入实体甚至不需要与部门有关系。这种一对一是无用的,可以替换为保留相关部门信息的连接实体的属性,例如其 objectID 或其他索引属性以达到它。

即:
部门员工:
属性:Dept_ix(整数)
关系:员工(对一,无效)

最佳答案


这是一个很好的问题。

但首先要注意的是:
它在 documentation 中明确说明:

"Important: You must define many-to-many relationships in both directions—that is, you must specify two relationships, each being the inverse of the other. You can’t just define a to-many relationship in one direction and try to use it as a many-to-many. If you do, you will end up with referential integrity problems."

无论如何,让我们描述问题(结果数据库)
定义一对多关系时,生成的数据库不会添加额外的表来映射关系。
它仅在一对多关系的一端设置实体的属性等于引用它的最后一项。

例子:

型号:
实体:部门
关系:无
属性:名称(字符串)

实体:员工
关系:部门(对多,无操作)
属性:名称

结果数据库:
Z部门:
Z_PK
Z_ENT
Z_OPT
Z2部门(内部)
ZNAME

Z员工:
Z_PK
Z_ENT
Z_OPT
ZNAME

这种结构显然会造成数据不一致。

解决方案是持有一个实体:DepartmentEmployee 对双向多对多关系进行建模,但其中一个是单向的(部门 -> DepartmentEmployee):

部门员工:
关系:部门(对一,不采取行动),员工(对一,无效)

并且您必须在删除部门对象时维护该表。

希望这是有道理的:)

关于ios - 如何强制单向对多关系持续存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15763125/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com