python - django 按日归档统计订单求解
问题描述
models.py:订单数据模型
class Order(models.Model): date = models.DateTimeField(default=timezone.now) paid_card = models.PositiveIntegerField(blank=True, null=True) paid_cash = models.PositiveIntegerField(blank=True, null=True) paid_gift = models.PositiveIntegerField(blank=True, null=True)statur = models.CharField() @property # 实收金额(paid_in) = paid_card + paid_cash + paid_gift def paid_in(self):return sum(filter(None, [self.paid_card, self.paid_cash, self.paid_gift]))
views.py: 按日归档统计每天的订单数、订单总额
def wx_archive(request): orders = Order.objects.filter(status=’closed’).annotate(day=TruncDay(’start_time’)).values(’day’).annotate(count=Count(’id’), total=Sum(’paid_in’)).values(’day’, ’count’, ’total’).order_by(’day’) return render(request, ’orders/archive.html’, {’orders’: orders})
运行后报错,提示
FieldError at /orders/archive/Cannot resolve keyword ’paid_in’ into field. Choices are: count, day, id, paid_card, paid_cash, paid_gift, status
请问,我该如何统计每日的总 paid_in?
问题解答
回答1:你的paid_in并不是数据库字段,很明显不能用在SQL语句中。两个方法:
把符合时间段的orders实例取出来,用时间筛选。然后Sum(所有的order.pard_in)
数据库层面Sum所有符合时间段的订单的paid_card, paid_cash, paid_gift
相关文章:
1. 修改mysql配置文件的默认字符集重启后依然不生效2. Java使用数组的速度比C ++中std :: vector快8倍。我做错什么了?3. html5 - 在Mac里使用vscode,却无法使用已下载的扩展……4. java - mybatis源码分析5. javascript - 项目用IE浏览器打开修改前端内容,后台数据修改了,但是前端页面内容不变,用谷歌浏览器测试前端页面可以刷新,求大神解决。6. Java:使用URL下载图片为何图片下载不完全呢?7. docker网络端口映射,没有方便点的操作方法么?8. css - html根字体设置成很大的值后, 包裹了行内元素的div莫名变高是什么原因9. browsersync一次只能检测一个HTML文件?10. 请教一个python字符串处理的问题?

网公网安备