为了一次获取所有朋友的详细信息,我使用 FQL 查询和带有错误处理程序的 FBRequestConnection 将所有数据保存到一个数组中,即
- (void)fetchFriendDetails
{
NSString* query = [NSString stringWithFormat:@"SELECT uid,name,birthday_date,pic_square FROM user WHERE uid IN (SELECT uid2 FROM friend WHERE uid1 = me())"];
// Set up the query parameter
NSDictionary *queryParam = [NSDictionary dictionaryWithObjectsAndKeys:
query, @"q", nil];
// Make the API request that uses FQL
[FBRequestConnection startWithGraphPath:@"/fql"
parameters:queryParam
HTTPMethod:@"GET"
completionHandler:^(FBRequestConnection *connection,
id result,
NSError *error) {
if (!error)
{
NSArray *tempArray = [result valueForKey:@"data"];
NSMutableArray *tempArrayAbout = [NSMutableArray arrayWithArray:tempArray];
self.friendsDetailsArray = tempArrayAbout;
NSLog(@"details are %@",friendsDetailsArray);
}
}];
}
当用户单击同步按钮时,将执行上述方法,然后执行将数据保存到数据库中。但是我这里有个问题!由于 FBRequestConnection 错误处理程序是一个回调函数,发生的情况是它最初不执行,并且对于第二次尝试,它进入并将所有朋友数据保存在FriendsDetailsArray中,这是我的同步按钮操作:
- (IBAction)syncSettings:(id)sender
{
if (self.remindBeforeDaysField.text.length != 0 && self.setTimeField.text.length != 0)
{
self.syncProgressHUD = [[MBProgressHUD alloc] initWithView:self.navigationController.view];
self.syncProgressHUD.labelText = kSyncingBirthdays;
self.syncProgressHUD.detailsLabelText = kPleaseWait;
self.syncProgressHUD.mode = MBProgressHUDModeIndeterminate;
[self.navigationController.view addSubview:syncProgressHUD];
syncProgressHUD.delegate = self;
dispatch_async(dispatch_get_global_queue( DISPATCH_QUEUE_PRIORITY_LOW, 0), ^{
// Do the task in the background
[syncProgressHUD show:YES];
[self saveUpdateFriendDetails];
// Hide the HUD in the main thread
dispatch_async(dispatch_get_main_queue(), ^{
[MBProgressHUD hideHUDForView:self.view animated:YES];
});
});
}
}
由于我的friendsDetailsArray有问题,我不得不将我的代码移动到viewDidLoad方法,就保存数据而言,这对我来说效果很好。我不明白为什么我无法更新数据,尽管我可以通过日志查看所有条件、数组值、包含所有 Facebook 好友 ID 的集合。换句话说,我可以保存好友详细信息,但无法更新。
令我惊讶的是,我在调试时发现了一些疯狂的事情,我已经检索了所有 Facebook 朋友 id(如果存在)并存储在 NSMutableSet 中,然后检查该集合是否包含我们的 Facebook 朋友 id 的条件,我想我的数据库是否已经保存朋友记录,那么条件应该是有效的,但令人震惊的是它没有验证并跳转到反之亦然的条件,即如果设置不包含我们的 Facebook id,这是我的示例实现代码:
-(void)saveUpdateFriendDetails
{
NSLog(@"reminder set values are %@",remindersSet);
NSLog(@"id is %@",facebookID);
if(updateIfExistSwitch.on && [remindersSet containsObject:facebookID])
{
//Do update stuff
}
else if(![remindersSet containsObject:facebookID])
{
//Do insertion stuff
}
}
这是用于澄清的记录输出:
正如我们在图像中观察到我的 Facebook id 存在于 NSMutableSet 即提醒集中,我不知道为什么条件:if(updateIfExistSwitch.on && [remindersSet containsObject:facebookID])没有被验证:O
此外,我相信在 viewDidLoad 中编写代码根本不是解决该场景的正确方法,谁知道呢,用户可能会输入详细信息并快速单击同步按钮,到时不会发生朋友详细信息的同步。我已经测试了场景也是。我认为所有的东西都围绕一个地方,即 FBRquestConnection 错误处理程序,我可以通过调试看到它不是第一次进入循环,而是第二次。
我希望先执行获取朋友详细信息操作,然后再将数据保存/更新到 sqlite 数据库。
注意:saveUpdateFriendDetails 是我保存或更新数据的方法,您可以观察同步按钮动作中的 [self saveUpdateFriendDetails] 行
有人可以指导我吗?
有用的建议鼓掌,在此先感谢:)