gpt4 book ai didi

objective-c - NSFetchRequest 求和、分组和排序

转载 作者:搜寻专家 更新时间:2023-10-30 19:44:08 24 4
gpt4 key购买 nike

在我的应用程序中,我试图列出四种最受欢迎​​ 的产品。
产品受欢迎程度取决于订单总量。

下面的查询是为了说明我正在尝试做的事情:

SELECT     TOP 4  SUM(quantity) as sumQuantity, Product
FROM [Order]
GROUP BY Product
ORDER BY 1 DESC

下面的代码是我在针对我的核心数据模型的获取请求中获取它的方法:

// Create an expression to sum the order quantity
NSExpressionDescription *sumExpression = [[NSExpressionDescription alloc] init];
sumExpression.name = @"sumQuantity";
sumExpression.expression = [NSExpression expressionWithFormat:@"@sum.%K", OrderAttributes.quantity];
sumExpression.expressionResultType = NSInteger32AttributeType;

// Create the fetch request
NSFetchRequest *request = [Order createFetchRequest];
request.resultType = NSDictionaryResultType;
request.propertiesToFetch = @[OrderRelationships.product, sumExpression];
request.propertiesToGroupBy = @[OrderRelationships.product];
request.sortDescriptors = @[[NSSortDescriptor sortDescriptorWithKey:sumExpression.name ascending:NO]];
request.fetchLimit = 4;

我的问题是 sortDescriptor,它似乎只允许 Order 的直接属性(应用程序异常(exception))。
排序非常重要,因为它决定了将返回哪四条记录。

注意:我使用的是 MagicalRecord 和 Mogenerator。我已经删除了类前缀。

最佳答案

不幸的是,NSSortDescriptor 想要一个实际的属性来排序,而不是动态计算的字段。根据您的情况,您可能希望在模型本身上保存所需的计数器并按其排序,或者获取整个图形并在内存中对其进行排序。

关于objective-c - NSFetchRequest 求和、分组和排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14794761/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com