本文介绍了数据库中行的核心数据主键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
的实例,为什么不创建一个从Foo
到Bar
的关联,并在相应的Foo
实例上将相应的Bar
实例设置为关联的目标。让核心数据跟踪对象ID。
这篇关于数据库中行的核心数据主键ID的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!