首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AddressBook与核心数据

AddressBook与核心数据
EN

Stack Overflow用户
提问于 2014-07-14 09:17:30
回答 1查看 629关注 0票数 0

我正在尝试制作一个应用程序,它将使用核心数据将通讯簿联系人的ID存储到SQLite文件中。

我的问题是,我想随机请求其中的一些ID,而联系人ID不可靠,因为联系人ID中可能有空白,所以我希望有一种索引属性,我可以对它进行随机操作,它永远不会有索引中的空白,如果我从数据库中删除了一些ID,我想确保索引被重新索引了(不确定索引是否是正确的名称,也许是一个键)。

核心数据会自动实现吗?默认情况下,它是否为我创建的任何数据模型创建一个键?如果是的话,我能访问它并利用它吗?如果我删除一行会发生什么?

抱歉,这可能是个初步问题。

另外,当通讯簿与SQLite一起更改时,更新我的ABAddressBookRegisterExternalChangeCallback(addressBook, addressBookChanged, *context)文件的最佳方法是什么?我还得把所有的通讯录重写到我的SQLite上吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-07-15 04:00:59

第一部分:

编写一个获取请求,该请求将返回所有联系人实体。然后使用-countForFetchRequest:确定您有多少。

在实体计数范围内生成一个随机整数。

现在编写另一个-fetchOffset等于随机整数的fetch请求,fetchLimit为1。

对于第2部分:ABExternalChangeCallback的文档没有列出任何参数来表示更改了哪些对象。但是您可以通过kABPersonModificationDateProperty对地址簿进行排序,并查看自上次同步以来更改的记录。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24733195

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档