我有一个名为Log
的模型,它有一个日期时间字段created_at
。
我想要做的是计算每个日期Log
的数量。
我试着这样做:
from django.db.models.functions import TruncDate
Log.objects.annotate(date=TruncDate('created_at')).values('date').annotate(c=Count('id'))
这给了我以下内容:
{'date': datetime.date(2018, 1, 17), 'count': 1}, {'date': datetime.date(2018, 1, 17), 'count': 1}, {'date': datetime.date(2018, 1, 17), 'count': 2}
也就是说,date
不是唯一的。
我想要的结果是:
{'date': datetime.date(2018, 1, 17), 'count': 4}, {'date': datetime.date(2018, 1, 18), 'count': 2}
如何解决这个问题?
答案 0 :(得分:1)
如果在Log
模型中设置默认排序,则会在查询的GROUP BY部分添加额外字段,这可能会导致此问题。尝试删除订购。
Log.objects.order_by().annotate(date=TruncDate('created_at')).values('date').annotate(c=Count('id'))
答案 1 :(得分:0)
您可以使用 distinct ()方法在Django中获取唯一值
<强>实施例强>
Log.objects.annotate(date=TruncDate('created_at')).values('date').distinct()