数据库中行的核心数据主键ID [英] Core Data primary key ID for a row in the database

查看:30
本文介绍了数据库中行的核心数据主键ID的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

假设我有一个存储在Core Data中的图书列表。我要按图书的主键ID搜索图书。

我知道Core Data创建的SQLite文件在每个表中都有一个ID列,但这似乎无论如何都不会向我公开。

有人有什么推荐吗?

推荐答案

-[NSManagedObject objectID]是对象实例在核心数据中的唯一ID。可以通过-[NSManagedObjectID URIRepresentation]进行序列化。您可以使用-[NSPersistentStoreCoordinator managedObjectIDForURIRepresentation:]从持久存储协调器检索objectID,然后使用-[NSManagedObjectContext objectWithID:]从托管对象上下文中获取对象。

但是

您应该记住,核心数据不是ORM。它是一个object graph management framework。也就是说,使用SQLite(和唯一的行ID)作为后端纯粹是一个实现细节。您越早摆脱SQL/RDBMS思维模式,您就越快对核心数据感到满意。与其试图从存储的ID中查找对象,不如考虑您为什么需要该对象,以及什么对象需要它。如果类Foo的实例需要能够到达类Bar的实例,为什么不创建一个从FooBar的关联,并在相应的Foo实例上将相应的Bar实例设置为关联的目标。让核心数据跟踪对象ID。

这篇关于数据库中行的核心数据主键ID的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆