我有一個出勤報告模型,工作人員在其中登記反饋和工作小時數等信息“nbr_heures”我的型號:class AttendanceReport(models.Model):
id=models.AutoField(primary_key=True)
consultant_id=models.ForeignKey(Consultant,on_delete=models.DO_NOTHING)
mission_id=models.ForeignKey(Mission,on_delete=models.CASCADE,null=True)
session_year_id=models.ForeignKey(SessionYearModel,on_delete=models.CASCADE, null=True)
nbr_heures = models.IntegerField(blank=False)
feedback = models.TextField(max_length=255,null=True, default="")
created_at=models.DateTimeField(auto_now_add=True)
updated_at=models.DateTimeField(auto_now_add=True)
objects=models.Manager()我正在嘗試對“nbr_heures”的值進行求和,我怎樣才能正確地做到這一點?我嘗試過這個但它不起作用.. hours_count=AttendanceReport.objects.annotate(nbr_heur=Sum('nbr_heures'))先感謝您。
1 回答

躍然一笑
TA貢獻1826條經驗 獲得超6個贊
你需要在這里.aggregate(…)
[Django-doc]:
hours_count = AttendanceReport.objects.aggregate(
? ? nbr_heur=Sum('nbr_heures')
)['nbr_heur']
An.aggregate(…)
將對查詢集中的所有記錄進行求和,而.annotate(…)
[Django-doc]將對每個對象(或每個唯一值,如果您使用)執行聚合.values(…)
。
添加回答
舉報
0/150
提交
取消