我从CoreData Entity
,Averaged
和GroupedBy
date
结果中获取了一些值。查询效果很好。现在......我想知道这些结果来自的dates
。显示的输出来自原始结果。我怎样才能使我的查询也吐出date
/ GroupBy value
(given that my GroupBy criteria is date)
,其中的平均值来自
输出
(
{
averageWeight = 36;
},
{
averageWeight = 22;
}
)
守则:
NSFetchRequest *request = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription entityForName:@"ExerciseData" inManagedObjectContext:context];
[request setEntity:entity];
// Specify that the request should return dictionaries.
[request setResultType:NSDictionaryResultType];
// Create an expression for the key path.
NSExpression *keyPathExpression = [NSExpression expressionForKeyPath:@"weight"];
// Create an expression to represent the function you want to apply
NSExpression *expression = [NSExpression expressionForFunction:@"average:"
arguments:@[keyPathExpression]];
// Create an expression description using the minExpression and returning a date.
NSExpressionDescription *expressionDescription = [[NSExpressionDescription alloc] init];
// The name is the key that will be used in the dictionary for the return value.
[expressionDescription setName:@"averageWeight"];
[expressionDescription setExpression:expression];
[expressionDescription setExpressionResultType:NSInteger32AttributeType]; // For example, NSDateAttributeType
// Set the request's properties to fetch just the property represented by the expressions.
[request setPropertiesToFetch:@[expressionDescription]];
request.predicate = [NSPredicate predicateWithFormat:@"exercise == %@",exercise];
[request setPropertiesToGroupBy:[NSArray arrayWithObject:@"date"]];
// Execute the fetch.
NSError *error;
NSArray *objects = [context executeFetchRequest:request error:&error];
NSLog(@"%@",objects);
答案 0 :(得分:1)
只需添加“date”作为另一个属性来获取:
[request setPropertiesToFetch:@[expressionDescription, @"date"]];