对符合条件的某个字段进行求和,聚合函数annotate()
开发环境:Ubuntu16.04+Django 1.11.9+Python2.7
对符合条件的某个字段求和
之前在开发的时候,有同事问Django...当时不知道这样的方法是否存在,但是想了想自己解决这类似问题的方法,先用filter将符合条件的取出来,然后进行for循环,取出需要的字段,进行求和.感觉是挺low的,于是一起Baidu,写代码测试最后找到了可以求值的方法...from django.db.models import Sum
from models import Book
all_price = Book.objects.values(‘price’).annotate...(num_books=Sum(‘price’)).filter(author=’Yu’)
print all_price[0][‘num_books’]
输出结果:650
上面的参数换个顺序,不会出错但不符合预期结果...all_youxibi[0][‘num_books’]
输出结果:’nums_book’
以上这篇Django ORM实现按天获取数据去重求和例子就是小编分享给大家的全部内容了,希望能给大家一个参考