如何提高核心数据的性能?

Jos*_*hua 14 iphone performance core-data nspredicate

我的应用程序有一个UISearchBar,允许用户输入搜索关键字.每次击键都会执行核心数据查询,以便将结果显示为搜索栏更改中的文本.

问题是搜索栏击键非常糟糕......当然是因为提取速度慢.任何想法如何提高性能?

我的核心数据由sqlite数据存储支持,其中包含1000个对象.

// searchKeyword is the string appears in UISearchBar
// Both title and author may contain several words so I can't use BEGINSWITH
NSPredicate* predicate = [NSPredicate predicateWithFormat:@"(author CONTAINS[c] %@) OR (title CONTAINS[c] %@)", searchKeyword, searchKeyword];

NSEntityDescription* entity = [NSEntityDescription entityForName:@"Book" inManagedObjectContext:managedObjectContext];

NSFetchRequest* request = [[NSFetchRequest alloc] init];
[request setEntity:entity];
[request setPredicate:predicate];
[request setFetchLimit:10];

NSSortDescriptor* sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"title" ascending:YES];
NSArray* sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil];
[request setSortDescriptors:sortDescriptors];

[sortDescriptor release];
[sortDescriptors release];

execute request and fetch the results
fetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:request
                                managedObjectContext:managedObjectContext
                                sectionNameKeyPath:nil
                                cacheName:nil];
NSError* error = nil;
BOOL success = [fetchedResultsController performFetch:&error];
[request release];
Run Code Online (Sandbox Code Playgroud)

Amy*_*all 18

使用CONTAINS可以减慢它的速度.您需要做的是创建一个名为searchWords(或其他)的新表,并在该商店中标题中的所有单词,小写并删除重音.这些关系将它们链接回原始对象.确保单词字段已编入索引.

在此表上执行查询,但不要使用CONTAINS或BEGINSWITH,而是执行类似的操作

单词>"term"和单词<"tern"

请注意,其中的第一个字符串是搜索项,第二个字符串是最后一个字符递增的搜索项.这允许Core Data使用SQL索引来执行搜索.

Apple有一个核心数据 WWDC会话,解释了这一点,包括示例代码.示例代码包含一个类,该类处理规范化字符串(即删除大小写),并以unicode感知方式递增单词的最后一个字符.


Mar*_*rra 13

虽然Amoyra的推荐是合理的,但您也有设计问题.

只有输入到搜索字段中的第一个字母应该永远打盘.在第一个字母之后,您应该只改进已经在内存中的搜索结果.

您应该使用已有的谓词过滤内存中的数组(从第一个字母搜索),并避免执行获取请求,因为它是不必要的.

此外,如果要搜索已经在内存中的数据(例如生活在a中NSFetchedResultsController),那么整个搜索应该只搜索内存中的对象.走向磁盘是不必要的,非常浪费.