2013-03-20 99 views
0

我不知道是否有可能与NSPredicate做到这一点:提前NSPredicate查询?

NSArray *letters = [[table.Letters componentsSeparatedByString:@","] mutableCopy]; 
NSArray *searched = [[searchString componentsSeparatedByString:@","] mutableCopy]; 
for (int i = 0; i<searched.count-1; i++) 
{ 
    if([letters[i] intValue] == [searched[i] intValue]) 
      //return the record 
    else 
      break; 
} 

我所做的基本上就是取每个字符串,以逗号分隔,并创建了一个整数数组(他们永远是整数)然后比较两者作为整数而不是字符串,以使其更快。

有没有办法用NSPredicate来做到这一点?或任何方式与CoreData做到这一点?

显然这些都不重要,这是我的Fetch请求。

-(void)titles:(NSString *)toMatch 
{ 
    // THIS IS ALL SETTING UP THE STRING TO BE MATCHED AGAINST THE DATABASE 

    NSMutableArray *retval = [[NSMutableArray alloc] init]; 
    NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults]; 
    lineIDArray = [[NSMutableArray alloc] init]; 
    NSString *LabelText =toMatch; 
    NSString *compareString = @""; 
    for (int i = 0; i<LabelText.length; i++) 
    { 
     int letter = [LabelText characterAtIndex:i]; 
     NSString *firstLetters; 
     if(letter<100) 
     { 
      firstLetters = [NSString stringWithFormat:@"0"]; 
      firstLetters = [blah stringByAppendingFormat:@"%d", letter]; 
     } 
     else 
      firstLetters = [NSString stringWithFormat:@"%d", letter]; 
     compareString= [compareString stringByAppendingString:firstLetters]; 
     compareString = [compareString stringByAppendingString:@","]; 
    } 
    //ALL THE WAY UP TO HERE 


    //SETTING UP QUERY 
    NSFetchRequest *request = [[NSFetchRequest alloc] init]; 
    NSPredicate *predicate; 

    //CHECKING WHICH TYPE OF SEARCH THE USER HAS SELECTED, MATCHING THE STRING FROM THE BEGINNING OR SEEING IF WHAT THEY SEARCHED ARE PRESENT IN THE FIRST LETTERS OF THE STRING 
    if ([defaults boolForKey:@"FLS"]) 
     predicate = [NSPredicate predicateWithFormat:@"first_letter_start BEGINSWITH %@", compareString]; 
    else 
     predicate = [NSPredicate predicateWithFormat:@"first_letter_start CONTAINS %@", compareString]; 

    //SETTING UP REQUEST 
    [request setPredicate:predicate]; 
    [request setReturnsObjectsAsFaults:NO]; 
    [request setFetchBatchSize:100]; 
    [request setEntity:entity]; 
    [request setPropertiesToFetch:[NSArray arrayWithObjects:@"gurmukhi", @"shabad_id", nil]]; 
    NSError *error; 

    //FETCHING 
    fetchedObjects = [managedObjectContext executeFetchRequest:request error:&error]; 
    for (Gurbani *shabad in fetchedObjects) 
    { 
     [retval addObject:shabad.gurmukhi]; 
     [lineIDArray addObject:[NSString stringWithFormat:@"%i", shabad.shabad_id]]; 
    } 
    searchResults = retval; 
    [searchResultsTable reloadData]; 
}; 

而这里的型号: Anything I'm searching regularly is indexed, including what I'm searching right now.

下面是使用参数-com.apple.CoreData.SQLDebug 1输出我得到:

2013-03-20 16:53:57.316 GurbaniKhoj[955:907] CoreData: sql: SELECT 0, t0.Z_PK FROM ZSHABAD t0 WHERE NSCoreDataStringSearch(t0.ZFIRST_LETTER_START, ?, 8, 0) 
2013-03-20 16:53:59.982 GurbaniKhoj[955:907] CoreData: annotation: sql connection fetch time: 2.6653s 
2013-03-20 16:53:59.983 GurbaniKhoj[955:907] CoreData: annotation: total fetch execution time: 2.6667s for 92 rows. 
2013-03-20 16:53:59.988 GurbaniKhoj[955:907] CoreData: sql: SELECT t0.Z_ENT, t0.Z_PK, t0.ZGURMUKHI, t0.ZSHABAD_ID FROM ZSHABAD t0 WHERE t0.Z_PK IN (?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) LIMIT 100 
2013-03-20 16:54:00.058 GurbaniKhoj[955:907] CoreData: annotation: sql connection fetch time: 0.0692s 
2013-03-20 16:54:00.059 GurbaniKhoj[955:907] CoreData: annotation: total fetch execution time: 0.0717s for 92 rows. 

我全新到这一点,所以也许这将帮助,我不知道该怎么做。

+0

你有没有验证,这其实是快? – 2013-03-20 17:51:12

+0

@TomHarrington我真的不确定,但是我问过的每个地方都被告知使用整数比较而不是字符串比较。 – Mukhi 2013-03-20 17:53:43

回答

0

你正在浪费你的时间。

NSDate *date = [NSDate date]; 
    NSArray *letters = [[@",,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,," componentsSeparatedByString:@","] mutableCopy]; 
    NSArray *searched = [[@",,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,," componentsSeparatedByString:@","] mutableCopy]; 
    for (int i = 0; i<searched.count-1; i++) 
    { 
    if([letters[i] intValue] == [searched[i] intValue]) 
    { 

    } 
//  NSLog(@"same"); 
    } 

    NSLog(@"ints: %f", [date timeIntervalSinceDate:[NSDate date]]); 

    date = [NSDate date]; 
    for (int i = 0; i<searched.count-1; i++) 
    { 
    if([letters[i] isEqualToString:searched[i]]) 
    { 

    } 
//  NSLog(@"same"); 
    } 
    NSLog(@"strings: %f", [date timeIntervalSinceDate:[NSDate date]]); 

整数:0.006064

字符串:0.000979

+0

这很奇怪,因为我在coreData中使用它,出于某种原因,Fetch需要3-4秒才能处理大约100行。我问过的其他地方我被告知这是因为字符串比较? – Mukhi 2013-03-20 17:52:28

+0

如果您正在进行单个提取请求,则无法花费3秒钟处理上百行。把你的获取请求代码和相关数据模型放在你的原始文章 – Eugene 2013-03-20 17:54:23

+0

好吧,刚刚添加它。 – Mukhi 2013-03-20 18:09:01