大佬教程收集整理的这篇文章主要介绍了ios – 在Parse中获取任意大量的对象,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的第一反应是不断查询数据库直到返回所有对象(例如“查询第一个1000,查询第二个1000,……”).在大多数情况下,这将是理想的,因为大多数用户将拥有少于1000个连接(可能更像是2-300左右).但是,如果某些用户的连接数量非常疯狂,那么这将无法正常工作 – 特别是因为Parse具有突发限制.
另一种选择似乎是使用Query.each方法,简单地迭代匹配查询的所有记录.我相信无论元素数量多少都会有效,所以这很好.然而,听起来这对于大尺寸来说相对较慢并且可能会超时.
那么,Parse的局限性最好的方法是什么呢?我希望它在相对较少数量的对象的常见情况下快速,但它肯定不会因边缘情况而中断.当然,一种选择是不进行此类查询,但在客户端进行所有连接非常有用.谢谢!
通过[query countObjectsInBACkgroundWithBlock]获取记录总数,并使用它来设置’skip’变量.为每1000条记录运行一个新查询,相应地更新skip属性
每个查询返回时正常处理记录.
您还需要一个帮助程序方法来确定所有查询何时完成,并且您已准备好在本地处理完整数据集.
像这样的东西:
//Define these as class-wide variables in your @interface - don't forget to @synthesize them too! int queriesToComplete; int completedQueries; NSMutableArray *completeDataArray = [[NSMutableArray alloc] init]; //Put in your query load function PFQuery *recordsCountQuery = [PFQuery queryWithClassName:@"YourClassName"]; [recordsCountQuery countObjectsInBACkgroundWithBlock:^(int number,NSError *error) { //Determine how many queries to run queriesToComplete = (int)ceil(number/1000) + 1; //Set the number of completed queries to zero completedQueries = 0; //Run a chain of queries - be sure to run them in the BACkground to prevent UI lockup for (int i = 0; i < queriesToComplete; i++) { PFQuery *chainQuery = [PFQuery queryWithClassName:@"YourClassName"]; //Add your other 'whereKey: equalTo:' type qualifiers here chainQuery.limit = 1000; chainQuery.skip = (i*1000); [chainQuery findObjectsInBACkgroundWithBlock:^(NSArray *objects,NSError *error) { //NSLog(@"query done"); [completeDataArray addObjectsFromArray:[objects copy]]; completedQueries ++; [self pullCompletioncheck]; }]; } }]; - (void)pullCompletioncheck{ if (self.queriesToComplete == self.completedQueries) { //All queries completed. //All data is Now in the completeDataArray } }
以上是大佬教程为你收集整理的ios – 在Parse中获取任意大量的对象全部内容,希望文章能够帮你解决ios – 在Parse中获取任意大量的对象所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。