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

37 篇文章 3 订阅

在使用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'))

在执行sql分组时,对日期进行格式化
分组过滤出每日用户新增数,并指定开始日期
sql实现

SELECT count(id) as nums, DATE_FORMAT(create_time, '%Y-%m-%d') as create_time FROM user_table where create_time > '2020-02-20' group by DATE_FORMAT(create_time, '%Y-%m-%d')

django ORM 的实现

from user.models import User
from django.db.models import Count
obj = User.objects.filter(create_time__gte='2020-02-20').extra(select={"create_time":"DATE_FORMAT(create_time, '%%Y-%%m-%%d')"}).values("create_time").annotate(nums=Count('id'))
print(obj)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

haeasringnar

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值