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