django中的分组聚合orm

本文详细介绍了Django ORM中如何进行分组查询、聚合函数的使用以及聚合计算,包括values、annotate、aggregate的配合使用,以及在聚合过程中如何进行过滤和计算。重点强调了values和annotate的位置对查询结果的影响,filter与annotate的顺序,以及F对象和Q对象的应用。通过实例展示了如何获取老师在每个班级发布的作业次数,并讨论了计算批改率时的数据类型转换问题。
摘要由CSDN通过智能技术生成

比如我们有这样三个model, 一个代表作业,一个代表作业发布的班级。HomeworkClass 表有外键homework_id关联Homework。
https://docs.djangoproject.com/zh-hans/2.2/topics/db/aggregation/

from django.db import models
class Homework(models.Model):
    id = models.BigIntegerField(primary_key=True)
    user_id = models.BigIntegerField(blank=True, null=True)        # 发布者id
    published_time = models.DateTimeField(blank=True, null=True)   # 作业布置时间
    end_time = models.DateTimeField(blank=True, null=True)         # 作业截止时间

    class Meta
        managed = False
        db_table = 'homework'


class HomeworkClass(models.Model):
    id = models.BigAutoField(primary_key=True)
    homework_id = models.ForeignKey(to=Homework, on_delete=models.SET_NULL,to_field='id',
                                    blank=True, null=True, db_constraint=False, db_column='homework_id')   # 作业id
    class_id = models.BigIntegerField(blank=True, null=True)      # 行政班班级id
    tmp_class_id = models.BigIntegerField(blank=True, null=True)  # 临时班班级id

    class Meta:
        managed = False
        db_table = 'homework_class'

class HomeworkStudent(models.Model):
    id = models.BigIntegerField(primary_key=True)
    # homework_id = models.BigIntegerField(blank=True, null=True)    # 作业id
    homework_id = models.ForeignKey
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值