0

我有一个SearchStringTooltipManagedObject。带属性@dynamic tooltipText;(NSString)

我需要在数据库中动态添加新的工具提示,但我只需要唯一值(不敏感)。

他们一次可以进来100多个;每次我检查唯一的..

看起来像:

    if (newTooltips.count == 0)
        return;

    NSEntityDescription *entity = [NSEntityDescription
                                   entityForName:@"SearchStringTooltip"
                                   inManagedObjectContext:self.moc];
    NSFetchRequest *request = [NSFetchRequest new];
    [request setEntity:entity];

       for (NSString *name in newTooltips) {

        [request setPredicate:[NSPredicate predicateWithFormat:@"tooltipText = %@", name]]; //like = (=) + time *2(sometimes *3) ofcourse i know i need like.. Its insensitive

        NSInteger count = [self.moc countForFetchRequest:request error:nil]; //But its is very expensive operation expensive
        if (count > 0) {
            continue;
        }

        DBSearchStringTooltip *tooltip = [NSEntityDescription insertNewObjectForEntityForName:@"SearchStringTooltip"
                                                                       inManagedObjectContext:self.moc];
        tooltip.tooltipText = name;
    }

我怎样才能更便宜地为内存做呢?可以有超过 10 000 个用于检查唯一性的工具提示......而且我必须全部检查。

4

2 回答 2

1

您可以尝试通过NSDictionaryResultType获取请求的结果类型和 setReturnsDistinctResults:YES 仅获取不同的 tooltipText。然后在内存中搜索结果。这可能比 10k 获取快得多,因为 fetch 总是命中磁盘。您可以在这里找到更多信息。

于 2013-03-20T17:40:31.970 回答
1

快速回答,我相信效率更高。使用此代码段而不是您的循环:

[request setPredicate:[NSPredicate predicateWithFormat:@"tooltipText IN %@", newTooltips]]; 
[request setResultType:NSDictionaryResultType];
[request setPropertiesToFetch:@[@"tooltipText"]];

NSArray* result = [self.moc executeFetchRequest:request error:nil]; 
NSArray* existingTooltipNames = [result valueForKey:@"tooltipText"]; 

NSMutableOrderedSet* itemsToAdd = [NSMutableOrderedSet orderedSetWithArray:newTooltips];
[itemsToAdd minusSet:[NSSet setWithArray:existingTooltipNames]];
for (NSString *name in itemsToAdd) {
    DBSearchStringTooltip *tooltip = [NSEntityDescription insertNewObjectForEntityForName:@"SearchStringTooltip" inManagedObjectContext:self.moc];
    tooltip.tooltipText = name;
}
于 2013-03-20T19:23:59.340 回答