Связанные выражения для выполнения вычислений в Core Data
Прежде всего: с новым годом :-)
Что я пытаюсь сделатьЯ пытаюсь разделить два атрибута в Базовых данных и затем вычислить среднее из этих делений. Атрибуты определяются путем ключа (например,eur
usd
aud
).
Пример: У меня есть следующий набор данных:
date eur usd aud
------------------------------
2010-01-01 0.5 1.0 1.5
2010-01-02 0.6 1.1 1.6
2010-01-03 0.4 1.0 1.3
Разделите два атрибута, например eur / usd с последующими результатами ...
divide eur / usd:
------------------
2010-01-01 0.5
2010-01-02 0.54
2010-01-03 0.4
... затем вычислите среднее значение этих чисел(0.5 + 0.54 + 0.4)/3 = 0.48
Поскольку я хотел бы, чтобы эти вычисления выполнялись непосредственно Core Data, я создал следующие выражения и запрос на выборку:
NSExpression *fromCurrencyPathExpression = [NSExpression
expressionForKeyPath:fromCurrency.lowercaseString];
NSExpression *toCurrencyPathExpression = [NSExpression
expressionForKeyPath:toCurrency.lowercaseString];
NSExpression *divisionExpression = [NSExpression
expressionForFunction:@"divide:by:"
arguments:@[fromCurrencyPathExpression,
toCurrencyPathExpression]];
NSExpression *averageExpression = [NSExpression expressionForFunction:@"average:"
arguments:@[divisionExpression]];
NSString *expressionName = @"averageRate";
NSExpressionDescription *expressionDescription =
[[NSExpressionDescription alloc] init];
expressionDescription.name = expressionName;
expressionDescription.expression = averageExpression;
expressionDescription.expressionResultType= NSDoubleAttributeType;
NSFetchRequest *request = [NSFetchRequest
fetchRequestWithEntityName:NSStringFromClass([self class])];
NSPredicate *predicate =
[NSPredicate predicateWithFormat:@"date >= %@ AND date