[Django-04]一对一,一对多

关系互相查询

    • 参数
    • [一对一 查询](#一对一 查询)
    • [一对多 查询](#一对多 查询)

参数

OneToOneField(),ForeignKey() 的参数如下

  1. to 要连接的模型
  2. to_field 要被关联的目标Model的字段
  3. on_delete 删除主表(被关联的表,也就是非OneToOneField,ForeignKey的表)时,当前表怎么处理。
    CASCADE->联动删除
    PROTECT ->抛出异常
    SET_NULL->设为null
    SET_DEFAULT->设为预定义的默认值
    SET->设置为指定的值
    DO_NOTHIND ->什么也不做
java 复制代码
class Grade(models.Model):
    id = models.AutoField(verbose_name='自增id', name="id", primary_key=True)
    grade_name = models.CharField(verbose_name="班级名称", name="grade_name", max_length=200)
    # grade_name = models.CharField(verbose_name="班级名称", db_column="grade_name", max_length=200)
    create_time = models.DateTimeField(verbose_name='创建时间',name="create_time", auto_now_add=True)  # 第一次赋值
    update_time = models.DateTimeField(verbose_name='最后一次更新时间',name="update_time", auto_now=True)  # 第二次赋值
    class Meta:
        db_table = "app_grade"
        ordering=["-update_time","create_time"]


class GradeManager(models.Model):
	"""
	一对一
	"""
    id = models.AutoField(verbose_name='自增id', name="id", primary_key=True)
    manager_name = models.CharField(verbose_name="班主任名称", db_column="manager_name", max_length=200,default=None)
    create_time = models.DateTimeField(verbose_name='创建时间',db_column="create_time", auto_now_add=True)  # 第一次赋值
    update_time = models.DateTimeField(verbose_name='最后一次更新时间',db_column="update_time", auto_now=True)  # 第二次赋值
    # 下面会在数据库中生成grade_id字段
    grade=models.OneToOneField(verbose_name='班主任表', to=Grade,on_delete=models.CASCADE)
    class Meta:
        db_table = "app_grade_manager"
        ordering=["-update_time","create_time"]

class Student(models.Model):
    """
    一对多
    to: 关联的父 类
    to_filed:
    外键要放在 多表中
    删除父表数据时,当前表与关联表的filed的行为。
    ForeignKey->字段名称会自动拼接id, 因此对应的序列化对象要加上id
    """
    id = models.AutoField(verbose_name='自增id', name="id", primary_key=True)
    name = models.CharField(verbose_name='名字', name='name', max_length=200)
    address = models.JSONField(verbose_name="地址信息", name="address")
    create_time = models.DateTimeField(verbose_name='创建时间', name='create_time', auto_now_add=True)  # 第一次赋值
    update_time = models.DateTimeField(verbose_name='最后一次更新时间', name='update_time', auto_now=True)  # 第二次赋值
    # 下面会在数据库生成grade_id字段
    grade = models.ForeignKey(verbose_name="关联外键", name="grade", to=Grade, on_delete=models.CASCADE)

    class Meta:
        db_table = "app_student"
        ordering=["-update_time","create_time"]

一对一 查询

python 复制代码
grade = Grade.objects.get(id=3)
print(grade.grademanager.manager_name) # 反向通过model小写名称引用
gradeManager = GradeManager.objects.get(id=1)
print(gradeManager.grade.grade_name) # 正向直接通过属性grade引用

一对多 查询

**************************************** 从查主,找到 "一" ************************************************

python 复制代码
grade = Grade.objects.get(id=3)
print(s.grade_id,s.grade.grade_name,s.grade.id)

*************************************** 主查从,找到"多" ************************************************

python 复制代码
 grade = Grade.objects.get(id=2)
 for student in grade.student_set.all():
	print(student.name)
相关推荐
coderSong25682 小时前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
老胖闲聊3 小时前
Python Copilot【代码辅助工具】 简介
开发语言·python·copilot
Blossom.1183 小时前
使用Python和Scikit-Learn实现机器学习模型调优
开发语言·人工智能·python·深度学习·目标检测·机器学习·scikit-learn
Mr_Air_Boy3 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
曹勖之3 小时前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?4 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
年老体衰按不动键盘4 小时前
快速部署和启动Vue3项目
java·javascript·vue
lyaihao4 小时前
使用python实现奔跑的线条效果
python·绘图
咖啡啡不加糖4 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
liuyang-neu4 小时前
java内存模型JMM
java·开发语言