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),那么整个搜索应该只搜索内存中的对象.走向磁盘是不必要的,非常浪费.
| 归档时间: |
|
| 查看次数: |
6346 次 |
| 最近记录: |