django orm 使用分组查询配合聚合查询,实现sql的group by count

在使用django时,有些条件下我们必须要使用聚合查询和分组查询时,但是有不想使用sql语句,那么就可以使用ORM提供的方法。
如果要实现如下sql语句:
就是先对course_id分组,然后确定每个组里面user_id的个数。

SELECT course_id,count(user_id) as usercount FROM test_bt4.course_user where is_delete = 0 group by course_id;
# 分组聚合查询
# 先导入聚合要使用的包
from django.db.models import Count
objs = CourseUser.objects.values('course_id').filter(is_delete=False).annotate(usercount=Count('user_id'))
print(objs)
#这个是否返回的是一组字典对象
for obj in objs:
    print(obj.get('course_id'),obj.get('usercount'))

猜你喜欢

转载自blog.csdn.net/haeasringnar/article/details/81557882