我正在尝试构建一个查询来获取“每个用户购买的商品的平均、最大和最小数量”。
数据源是这个简单的销售记录表:
class SalesRecord(models.Model):
id = models.IntegerField(primary_key=True)
user_id = models.IntegerField()
product_code = models.CharField()
price = models.IntegerField()
created_at = models.DateTimeField()
对于用户购买的每件商品,都会在此表中插入一条新记录。【注意】:user_id
不是同一个数据库中表的外键,因为这个后台系统不管理用户信息。该值由产品的前端部分提供。
这是我构建查询的尝试:
q = SalesRecord.objects.all()
q = q.values('user_id').annotate( # group by user and count the # of records
count=Count('id'), # (= # of items)
).order_by()
result = q.aggregate(Max('count'), Min('count'), Avg('count'))
当我尝试执行代码时,ProgrammingError
在最后一行引发了 a:
(1064,“您的 SQL 语法有错误;请查看与您的 MySQL 服务器版本相对应的手册,以了解在 'FROM (SELECT
sales_records
.user_id
ASuser_id
, COUNT(sales_records
.`' at line 1) 附近使用的正确语法”)
Django 的错误屏幕显示 SQL 是
SELECT FROM
(SELECT
`sales_records`.`user_id` AS `user_id`,
COUNT(`sales_records`.`id`) AS `count`
FROM `sales_records`
WHERE (`sales_records`.`created_at` >= %s AND `sales_records`.`created_at` <= %s )
GROUP BY `sales_records`.`user_id` ORDER BY NULL) subquery
它没有选择任何东西!有人可以告诉我正确的方法吗?
入侵 Django
我发现清除所选字段的缓存django.db.models.sql.query.BaseQuery.get_aggregation()
似乎可以解决问题。虽然我不确定这是修复还是解决方法。
@@ -327,10 +327,13 @@
# Remove any aggregates marked for reduction from the subquery
# and move them to the outer AggregateQuery.
+ self._aggregate_select_cache = None
+ self.aggregate_select_mask = None
for alias, aggregate in self.aggregate_select.items():
if aggregate.is_summary:
query.aggregate_select[alias] = aggregate
- del obj.aggregate_select[alias]
+ if alias in obj.aggregate_select:
+ del obj.aggregate_select[alias]
...产生结果:
{'count__max': 267, 'count__avg': 26.2563, 'count__min': 1}