(声明)
表名小写➕_set 得到的是一个QuerySet集合,后面可以跟 .add() .remove() .update() .clear() ,,,,,但是但是但是但是 在建立多对多关系的时候加上了 related_name=‘自己建立的名称’ 那就不能用’表名小写_+set’ 了 ,那时候就要用 ‘自己建立的名称’ 了
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') #多对多关系
- 通过学生添加手机之间的关系
#通过学生添加手机 (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 ')
- 通过手机添加学生之间的关系
# 通过手机添加学生(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
- 通过学生删除与手机之间的关系
#通过学生删除手机(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
- 通过手机来删除与学生之间的关系
#通过手机删除学生 (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')