表名小写+_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')