NSFetchedResultsCotroller
使用谓词时,行为异常。以下代码显示输出:
Rows - 0
但是当我注释掉[self saveContext]
(第一个)时,输出变为:
Rows - 1
删除谓词(query.predicate
)可以修复问题,并且输出始终为:
Rows - 1
我怀疑这NULL
与内存与数据库查询中的比较方式有关。知道到底发生了什么吗?
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
NSError *error;
// Deletes persistent store coordinator behind the scene
// Create an empty entity with the optional fields attr1 (string) and attr2 (date)
Entity *e = [NSEntityDescription insertNewObjectForEntityForName:@"Entity" inManagedObjectContext:[self managedObjectContext]];
[self saveContext]; // <---------------- Code to comment out
// Setup fetched results controller
NSPredicate *pred = [NSPredicate predicateWithFormat:@"(attr1 != %@) AND (attr2 != %@)", @"", [NSDate new], nil];
NSFetchRequest *query = [[NSFetchRequest alloc] initWithEntityName:@"Entity"];
query.predicate = pred;
query.sortDescriptors = @[[NSSortDescriptor sortDescriptorWithKey:@"attr1" ascending:NO]];
frc = [[NSFetchedResultsController alloc] initWithFetchRequest:query managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil cacheName:nil];
frc.delegate = self;
[frc performFetch:&error];
// Output #1
NSLog(@"Rows - %ld", frc.fetchedObjects.count);
[self saveContext];
return YES;
}
- (void)controllerDidChangeContent:(NSFetchedResultsController *)controller
{
NSLog(@"Rows - %ld (Update)", controller.fetchedObjects.count);
}
编辑:
修改谓词似乎可以解决该问题。仍然不知道为什么:
NSPredicate *pred = [NSPredicate predicateWithFormat:@"((attr1 = NULL) OR (attr1 != %@)) AND ((attr2 = NULL) OR (attr2 != %@))", @"", date];
是的,我怀疑这与您的谓词有关。我认为nil
作为替换对象的行为是不可预测的。您可以使用NULL
或nil
在格式字符串本身或代表空一个真正的对象,即[NSNull null]
。如果您尝试这样做,也许您的原始谓词也将起作用。
但是还有其他事情发生。也许您的实体有一些使谓词失败的默认值,这可以解释为什么在某些情况下保存会更改获取结果的原因。同样,还不清楚该saveContext
方法的内容是什么。
同样,不是这样[NSDate new]
会产生精确到1/10000秒的日期,因此谓词的这一部分应始终返回true
。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句