Как выполнить запрос на выборку, чтобы получить сумму параметра с описанием выражения?

Это мой запрос на получение:

    let request = NSFetchRequest<Service>()
    let sorter = NSSortDescriptor(key: "date", ascending: true)

    let entity = NSEntityDescription()
    entity.name = "Service"
    request.entity = entity
    request.sortDescriptors = [sorter]
    request.resultType = .dictionaryResultType
    request.predicate = NSPredicate(format: "month.identifier = 201703")

    let exp = NSExpressionDescription()
    exp.expression = NSExpression(forKeyPath: "@sum.duration")
    exp.expressionResultType = .integer64AttributeType
    request.propertiesToFetch = [exp]

    do {
        let result = try NSManagedObjectContext.mr_default().fetch(request) //error is here
        print("+++++ \(result)")
    } catch {
        print(error)
    }

Но выдает ошибку:

* Завершение работы приложения из-за необработанного исключения "NSInvalidArgumentException", причина: "* -[__NSArrayM insertObject:atIndex:]: объект не может быть нулевым"

Почему?


person Bartłomiej Semańczyk    schedule 01.07.2017    source источник


Ответы (1)


Задайте имя для NSExpressionDescription. Имя — это ключ, который будет использоваться в словаре для возвращаемого значения. Я изменил тип результата для запроса на выборку, чтобы он работал для типа словаря.

    let request = NSFetchRequest<NSFetchRequestResult>()
    let sorter = NSSortDescriptor(key: "date", ascending: true)

    let entity = NSEntityDescription()
    entity.name = "Service"
    request.entity = entity
    request.sortDescriptors = [sorter]
    request.resultType = .dictionaryResultType
    request.predicate = NSPredicate(format: "month.identifier = 201703")

    let exp = NSExpressionDescription()
    exp.name = "sumOfduration"
    exp.expression = NSExpression(forKeyPath: "@sum.duration")
    exp.expressionResultType = . integer64AttributeType
    request.propertiesToFetch = [exp]

    do {
        let result = try UMUserDBManager.sharedInstance.getThreadManagedObjectContext().fetch(request) //error is here
        print("+++++ \(result)")
    } catch {
        print(error)
    }

}
person pkallu    schedule 01.07.2017