你的位置:首页 > 信息动态 > 新闻中心
信息动态
联系我们

Pycharm开发Django项目ORM作业

2021/11/6 10:42:38

ORM作业:

假设有以下ORM模型:

from django.db import models

class Student(models.Model):
“”“学生表”""
name = models.CharField(max_length=100)
gender = models.SmallIntegerField()

class Meta:
    db_table = 'student'

class Course(models.Model):
“”“课程表”""
name = models.CharField(max_length=100)
teacher = models.ForeignKey(“Teacher”,on_delete=models.SET_NULL,null=True)
class Meta:
db_table = ‘course’

class Score(models.Model):
“”“分数表”""
student = models.ForeignKey(“Student”,on_delete=models.CASCADE)
course = models.ForeignKey(“Course”,on_delete=models.CASCADE)
number = models.FloatField()

class Meta:
    db_table = 'score'

class Teacher(models.Model):
“”“老师表”""
name = models.CharField(max_length=100)

class Meta:
    db_table = 'teacher'

使用之前学到过的操作实现下面的查询操作:

查询平均成绩大于60分的同学的id和平均成绩;

查询所有同学的id、姓名、选课的数量、总成绩;

查询姓“李”的老师的个数;

查询没学过“李老师”课的同学的id、姓名;

查询学过课程id为1和2的所有同学的id、姓名;

查询学过“黄老师”所教的“所有课”的同学的id、姓名;

查询所有课程成绩小于60分的同学的id和姓名;

查询没有学全所有课的同学的id、姓名;

查询所有学生的姓名、平均分,并且按照平均分从高到低排序;

查询各科成绩的最高和最低分,以如下形式显示:课程ID,课程名称,最高分,最低分;

查询没门课程的平均成绩,按照平均成绩进行排序;

统计总共有多少女生,多少男生;

将“黄老师”的每一门课程都在原来的基础之上加5分;

查询两门以上不及格的同学的id、姓名、以及不及格课程数;

查询每门课的选课人数;