我有一個像這樣的簡單模型:class Order(models.Model): created = model.DateTimeField(auto_now_add=True) total = models.IntegerField() # monetary value我想逐個輸出:一個月有多少銷售額(COUNT)合并值(SUM)我不確定攻擊它的最佳方法是什么。我已經看到了一些相當可怕的額外選擇查詢,但我簡單的想法告訴我,我可能會更好的只是迭代數字,從任意的開始年/月開始計算直到我到達當前月份,拋棄簡單查詢過濾該月份。更多數據庫工作 - 減少開發人員的壓什么對你最有意義?有沒有一種很好的方法可以撤回快速的數據表?或者我的臟方法可能是最好的主意?我正在使用Django 1.3。不確定他們最近是否添加了更好的方式GROUP_BY。
3 回答

UYOU
TA貢獻1878條經驗 獲得超4個贊
另一種方法是使用ExtractMonth。由于只返回了一個日期時間年值,因此使用TruncMonth遇到了麻煩。例如,僅返回2009年的月份。ExtractMonth完美地解決了這個問題,可以像下面這樣使用:
from django.db.models.functions import ExtractMonth
Sales.objects
.annotate(month=ExtractMonth('timestamp'))
.values('month')
.annotate(count=Count('id'))
.values('month', 'count')
- 3 回答
- 0 關注
- 2075 瀏覽
添加回答
舉報
0/150
提交
取消