多对一关系
生活中的多对一关系:班主任,班级关系。一个班主任可以带很多班级,但是每个班级只能有一个班主任
from django.db import models # id name gender 定义老师的模型类 class Teacher(models.Model): name = models.CharField(max_length=30,verbose_name="老师姓名") gender = models.CharField(max_length=10,verbose_name="老师性别") class Meta: db_table = "teachers" def __str__(self): return self.name # id name gender score teacher_id class Student(models.Model): name = models.CharField(max_length=20,verbose_name="学生姓名") gender = models.CharField(max_length=10,verbose_name="学生性别") score = models.IntegerField(verbose_name="学生分数") # to:后边写所关联的模型类 # on_delete=models.CASCADE:主表中数据删除,从表也删除 # 外键关联的是整个模型类,不是单独的某一个对象 # 但是通过模型类会产生一个相关联的字段 字段名_id teacher = models.ForeignKey(to=Teacher,on_delete=models.CASCADE,verbose_name="所属老师") class Meta: db_table = "students" def __str__(self): return self.name
添加老师语法: 模型类.objects.create() Teacher.objects.create(name="王老师",gender="女") 删除老师语法: 模型类.objects.get(条件).delete() # 删除id为2的老师 Teacher.objects.get(id=2).delete() # (3, {'myapp.Student': 2, 'myapp.Teacher': 1}) # 3代表一共删除的数据个数 Student删除3条 Teacher删除1 修改老师语法: 模型类.objects.filter(条件).update() # 修改id为3的老师性别为女 Teacher.objects.filter(id=3).update(gender="女")
添加学生语法: 模型类.objects.create() 通过外键_id的形式来添加 Student.objects.create(name="李四",gender="男",score=80,teacher_id=3) 直接给外键赋值一个老师对象 t1 = Teacher.objects.create(name="李老师",gender="男") Student.objects.create(name="李四",gender="男",score=80,teacher=t1) 删除学生语法: 模型类.objects.get(条件).delete() Student.objects.get(id=1).delete() 修改学生语法: 模型类.objects.filter(条件).update(字段1,字段2...) Student.objects.get(id=1).update(name="张三")
# 查询id为2的学生的老师姓名 --找到id为2的学生 stu = Student.objects.get(id=2) --找到stu对应的老师 stu.teacher.name stu.外键.name
反向查询:通过django的内置属性来进行查询 模型类(模型类小写)_set()可以反向查询老师名下的所有学生, # 查询id为1的老师的所有学生 --先找到id为1的老师 tea = Teacher.objects.get(id=1) --查询tea老师名下的所有学生 老师对象.模型类_set.all() tea.student_set.all()
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现