django中的分组聚合orm

比如我们有这样三个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、付费专栏及课程。

余额充值