zoukankan      html  css  js  c++  java
  • 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')
    复制代码
  • 相关阅读:
    腾讯云挂载文件服务器节点
    OpsManage 安装
    centos7 安装mysql
    vs code 新建vue项目
    Centos7 安装supervisor
    腾讯云Centos7 安装nginx
    django 生成pdf
    VM安装虚拟机
    ACM/ICPC 之 Floyd练习六道(ZOJ2027-POJ2253-POJ2472-POJ1125-POJ1603-POJ2607)
    ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)
  • 原文地址:https://www.cnblogs.com/ngngng/p/13891149.html
Copyright © 2011-2022 走看看