我正在尝试制作一个应用程序,它将使用核心数据将通讯簿联系人的ID存储到SQLite文件中。
我的问题是,我想随机请求其中的一些ID,而联系人ID不可靠,因为联系人ID中可能有空白,所以我希望有一种索引属性,我可以对它进行随机操作,它永远不会有索引中的空白,如果我从数据库中删除了一些ID,我想确保索引被重新索引了(不确定索引是否是正确的名称,也许是一个键)。
核心数据会自动实现吗?默认情况下,它是否为我创建的任何数据模型创建一个键?如果是的话,我能访问它并利用它吗?如果我删除一行会发生什么?
抱歉,这可能是个初步问题。
另外,当通讯簿与SQLite一起更改时,更新我的ABAddressBookRegisterExternalChangeCallback(addressBook, addressBookChanged, *context)文件的最佳方法是什么?我还得把所有的通讯录重写到我的SQLite上吗?
发布于 2014-07-15 04:00:59
第一部分:
编写一个获取请求,该请求将返回所有联系人实体。然后使用-countForFetchRequest:确定您有多少。
在实体计数范围内生成一个随机整数。
现在编写另一个-fetchOffset等于随机整数的fetch请求,fetchLimit为1。
对于第2部分:ABExternalChangeCallback的文档没有列出任何参数来表示更改了哪些对象。但是您可以通过kABPersonModificationDateProperty对地址簿进行排序,并查看自上次同步以来更改的记录。
https://stackoverflow.com/questions/24733195
复制相似问题