django一对一,一对多,多对多的增删改查

本文详细介绍了Django中一对一、一对多和多对多关系的创建、查询、修改和删除操作。对于一对一关系,通过man__字段名进行查询,使用on_delete属性处理删除行为。在多对一关系中,利用_set进行反向查询,而多对多关系则通过add函数添加关联,使用remove移除关联。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一对一关系

一对一反向查询
直接用小写类名
创建:
关联关系的数据创建
先得把那个关联的值创建出来
然后再赋值到这个字段上
m1 = Man
f1 = Father(man=m1)
字典导入:
color_obj=models.主表.objects.create(colors=“黑”)
ball_dic={‘description’:“黑球”}
models.子表.objects.create(color=color_obj,**ball_dic)

查询
从表的层面:
从Father查。名字是李四的父亲
Father(man__字段名=’’)
res = models.Father.objects.filter(man__name__startswith=‘李’)
查询所有小孩名为聪明的小孩的父亲
res = models.Father.objects.filter(babe__startswith=‘聪明’)
从数据的层面:
获取到一个Father数据的Man数据
res.man.name
获取一个Man是不是一个Father
不能的:OneToOneField
改:
找一个关联字段的同类数据
直接赋值即可,记得save
删:
on_delete=models.SET_NULL
关联数据删除,本数据不动
on_delete=models.CASCADE
关联数据删除,全部删除
一对一反向查询
数据层面:直接小写类名
表层面:直接小写类名

多对一关系
创建数据
首先创建老师数据
t1 = models.Teacher.objects.create(name=‘李老师’)
再创建学生数据
s1 = models.Student.objects.create(teacher=t1,name=‘张同学’)
查询:
表层面:
查询所有李老师的学生
models.Student.objects.filter(teacher__name=‘李老师’)
正向查询
带张同学的老师:
models.Teacher.objects.filter(student__name=‘张同学’)
反向查询
数据层面:
张同学的老师:正向查询
s1.teacher
李老师的全部学生:反向查询
student_set == Student.objects
改:
字段赋值再save
删:
直接delete,根据on_delete属性设置,做不同的动作
将李老师的所有学生删除
t1.student_set.all().delete()
models.Teacher.objects.all().delete()

多对一关系反向查询
数据层面:必须用小写类名_set
表层面:直接小写类名

多对多字段
创建
add函数添加关联关系
sts.teacher.add(参数部分可以添加多个外键关联的值)
sts.teacher = 一对一多对一
查询:
正向查询:查询一个学生所有的老师
反向查询:
数据层面:
查询一个老师所有的学生
t1.student_set.all()
表层面:
查询带学生3的老师
HandSomeTeacher.objects.filter(student__name=‘学生3’)
删除:
直接删除数据
t1.delete()
删除外键关系:数据还在
remove(t1,t2,t3)
多对多反向查询
数据层面:必须用小写类名_set
表层面:直接小写类名

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值