Django多对多
表名小写+_set() 得到的是一个QuertSet集合,她的后面可以跟 .add() .remove() .update() .clear()
models.py 文件
# 学生表
class Student(models.Model):
name = models.CharField(max_length=30,default='') #学生的姓名 #手机表 一个学生可以选择多个手机品牌 , 一个品牌可以有多个学生选择
class Phone(models.Model):
name = models.CharField(max_length=40) #手机名称
stu = models.ManyToManyField(to='Student') #多对多关系
1.通过学生添加手机之间的关系
#通过学生添加手机 (CBV)
class Stu_phoneadd(View):
def get(self,request):
stu = Student.objects.filter(id=7).first() #通过学生ID查找学生
phone = Phone.objects.filter(id=3).first() #通过手机ID查找
stu.phone_set.add(phone)
return HttpResponse('ok ')
2.通过手机添加学生之间的关系
# 通过手机添加学生(CBV)
class Phone_stuadd(View):
def get(self,request):
phone = Phone.objects.filter(id=3).first() #通过ID来获取这个品牌的手机
stu = Student.objects.filter(id=1).first() #通过ID来获取这个学生
phone.stu.add(stu) #最后建立关系 return HttpResponse('okok') #返回给网页一个OK
3.通过学生删除与手机之间的关系
#通过学生删除手机(CBV)
class Del_stu(View):
def get(self,request):
stu = Student.objects.filter(id=1).first() #通过ID来获取学生
phone = Phone.objects.filter(id=2).first() #通过ID来获取手机
stu.phone_set.remove(phone) #最后通过表名小写_set 加remove 来删除学生和手机之间的关系
return HttpResponse('ko ok ') #返回给网页一个OK
4.通过手机来删除与学生之间的关系
#通过手机删除学生 (CBV)
class Del_phone(View):
def get(self,request):
phone = Phone.objects.filter(id=3).first() #通过ID来获取手机
stu = Student.objects.filter(id=1).first() #通过ID来获取学生
phone.stu.remove(stu) #最后通过表名小写来删除两者之间的关系
return HttpResponse('ok ko')
Django多对多的更多相关文章
- Python学习---django多对多自定义第三方表180206
案例一: # version: python3.2.5 # author: 'FTL1012' # time: 2018/2/6 16:25 from django.db import models ...
- Django多对多关系建立及Form组件
目录 Django多对多关系 1.创建方式一全自动 2.创建方式二纯手撸 3.半自动(推荐使用) forms校验组件 使用forms组件实现注册功能 form常用字段和插件 数据校验 钩子函数 HOO ...
- django 多对多 增 删 改 查
一.通过url方式实现多对多的:增加,删除,编辑 代码目录: urls.py 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ...
- django -- 多对多关系的实现
在django中表和表之间的多对多关系有两种实现方案: 方案一:直接使用django自动实现的多对多关系. 方案二:自己写连接表.然而告诉django在实现多对多关系时要使用的连接表. 一.方案一: ...
- django多对多中间表详解
我们都知道对于ManyToMany字段,Django采用的是第三张中间表的方式.通过这第三张表,来关联ManyToMany的双方.下面我们根据一个具体的例子,详细解说中间表的使用. 一.默认中间表 首 ...
- Django多对多的创建
1.多对多创建的应用场景: 在某表中创建一行数据是,有一个可以多选的下拉框 例如:创建用户信息,需要为用户指定多个爱好 2.创建方式: 方式一:自定义关系表,手动创建一张表用于关联其他多张表的关系 c ...
- Django多对多表的三种创建方式,MTV与MVC概念
MTV与MVC MTV模型(django): M:模型层(models.py) T:templates V:views MVC模型: M:模型层(models.py) V:视图层(views.py) ...
- Django --- 多对多关系创建,forms组件
目录 多对多三种创建方式 1.系统直接创建 2.自己手动创建 3.自己定义加与系统创建 forms组件 1. 如何使用forms组件 2. 使用forms组件校验数据 3. 使用forms组件渲染标签 ...
- Django 多对多 关系
多对多,本意就是多个一对多的关系 定义多对多 ManyToManyField 字段 from django.db import models # 学生类 class Student(models.Mo ...
- 【Python】django多对多 查询 ,反查等操作
The Django Book中这样写 但我使用属性名后加_set会报错 而直接用members = group.user_group_join.all() 就可以 可能因为我的MyUser类里有两个 ...
随机推荐
- vmware安装Linux
- SPSS python教程:[1]安装Python Essentials
python机器学习-乳腺癌细胞挖掘(博主亲自录制视频)https://study.163.com/course/introduction.htm?courseId=1005269003&ut ...
- ELK的安全解决方案 X-Pack(1)
安装 X-Pack 前必须安装 elasticsearch. Kibana.logstash,因为之前安装ELK选择的版本都是5.4.1,所以这次选择X-Pack的版本也要是5.4.1的 第一步:下载 ...
- ubuntu18 faster-rcnn
luo@luo-All-Series:~/MyFile$ luo@luo-All-Series:~/MyFile$ luo@luo-All-Series:~/MyFile$ git clone htt ...
- Linux命令之ntpdate、hwclock
ntpdate用于同步系统时间.hwclock用于同步硬件时间. (1).ntpdate ntpdate [选项] [时间服务器] 一般直接ntpdate [时间服务器] 常用的时间服务器:ntp[1 ...
- PHPCMS get SQL 返回单条的办法
{pc:get sql="SELECT * FROM v9_member_detail where userid=1" num="1" return=" ...
- Pedro domingos
Dear Professor: I am a university student in China and study on MLN recently; ...
- 重置fedora root密码
本方法适用于fedora16(含)以上(使用GRUB2) 步骤如下: Step 1:系统菜单,在linux上按“e”键进行编辑 Step 2:使用上下键找到以字符串“linux”或“linux16”( ...
- 【Matlab开发】matlab中norm范数以及向量点积、绘图设置相关
[Matlab开发]matlab中norm范数以及向量点积.绘图设置相关 标签(空格分隔): [Matlab开发] 声明:引用请注明出处http://blog.csdn.net/lg125915677 ...
- SSH连接时root用户无法验证通过
解决办法是: vi /etc/ssh/sshd_config 找到 # Authentication: PermitRootLogin without passwd 改成 # Authenticati ...