作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对如何在 CoreData 中对此建模感到有点困惑?这是一个相当简单的概念,我希望能够跟踪玩家在某个游戏中玩了多长时间。所以我有以下对象(为简洁起见进行了简化):
Player
- name
- currentGamePlayedTime
(1:1 relationship to Team)
Team
- name
(1:1 relationship with Player)
(1:Many relationship with Game
Game
- date
(Many:1 relationship with Team)
我希望能够回顾某个球员在某场比赛中的上场时间,或者看到整个球队在一场比赛中的上场时间。但我不确定如何建模。使用 SQL 方法,我会有一个中间表(如下所示),并且有 15 个左右的条目,每个条目对应参与游戏的每个玩家以及他们玩的相应时间。
GameRecord
- GameID
- PlayerID
- TimePlayed
我的应用程序能够计算出玩家在当前游戏中玩了多少游戏并将其存储在当前的 Player 对象中,但我不知道将播放时间保存到相应的 Game 对象的长期解决方案 - 是否直接在物体上或通过中间体。
我见过一些 people do use intermediates .但我还读到,使用 SQL 实践并不是考虑对象图的编写方式。所以只是想知道应该如何为这样的东西建模。
最佳答案
使用中间实体来模拟多对多关系是完全合法的。事实上,在像您这样的情况下,您需要存储有关关系本身的信息。
Core Data Programming Guide 中有一个这样的例子,在标题为“基于语义建模关系”的部分中(无论是什么意思)。他们的示例是自反关系,但该论点适用于任何多对多关系。
关于ios - CoreData 和中间体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42676886/
我是一名优秀的程序员,十分优秀!