-1

2 つのモデル Practice と PracticeRecord があり、それらの間に対多の関係があります。ここで、関連する practiceRecord オブジェクトの数が最小であるが 0 より大きい Practice オブジェクトの配列を取得したいと考えています。以下のコードを書きましたが、うまくいかず、リクエストの取得時に例外が発生しました。誰でもエレガントな解決策を教えてください。前もって感謝します。

NSFetchRequest *request = [NSFetchRequest fetchRequestWithEntityName:@"Practice"];

request.predicate = [NSPredicate predicateWithFormat:@"practiceRecords.@count > 0"];    

[request setResultType:NSDictionaryResultType];

NSExpression *keyPathExpression = [NSExpression expressionForKeyPath:@"practiceRecords.@count"];
NSExpression *minExpression = [NSExpression expressionForFunction:@"min:" arguments:[NSArray arrayWithObject:keyPathExpression]];
NSExpressionDescription *expressionDescription = [[NSExpressionDescription alloc] init];
[expressionDescription setName:@"minPracticeRecordTimes"];
[expressionDescription setExpression:minExpression];
[expressionDescription setExpressionResultType:NSDecimalAttributeType];
[request setPropertiesToFetch:[NSArray arrayWithObject:expressionDescription]];

NSError *error = nil;
NSArray *objects = [context executeFetchRequest:request error:&error];
if (objects == nil) {
    // Handle the error.
}
else {
    if ([objects count] > 0) {
        NSLog(@"Minimum practice record times: %@", [[objects objectAtIndex:0]
                                    valueForKey:@"minPracticeRecordTimes"]);
    }
}
4

1 に答える 1

0

practiceRecords.@count問題は、キーパスで集計関数 ( )を使用していると思います

これが生成する SQL を考えると、次のようになります。

SELECT min(count(practiceRecords)) AS minPracticeRecordTimes
FROM Practice
WHERE count(practiceRecords) > 0

これはもちろん無効です。

これを行う必要がある場合は、エンティティを少し非正規化し、 が追加または削除されるたびに更新される にcountフィールドを追加してから、ストレート フェッチ リクエストを使用できます。PracticePracticeRecord

于 2012-07-03T14:45:54.193 に答える