美文网首页
Django 关联模型和关联查询

Django 关联模型和关联查询

作者: LittleTrue | 来源:发表于2019-02-17 20:15 被阅读0次
    了解前提:模型的查询对象

    三种模型

    一对一模型:关系字段定义在任意一端中
    一对多模型:关系字段定义在多的一端中;一对多中,外键对应的是主表的一个对象,而不是一个单纯的id

    多对多模型:自动生成第三张表,第三张表为关系表;先实例化对象添加两张表,然后再添加关系

    在模型中建立以下关联字段

    建立各种关系参考

     定义模型关系和关联字段
     #学生表与班级是一对多
        g = models.ForeignKey(to="Grade", to_field="Grade_id")
    
     #学生信息表与学生表一对一
        stu = models.OneToOneField(to="Student", to_field="Student_id")
    
     #课程表与学生表是多对多
        stu = models.ManyToManyField(to="Student", to_field="Student_id")
    

    关联查询进行:

    一对一操作关联查询:
    前提: 由学生信息表Student 查询学生详情表 StudentDetail ,
    Student 定义: detail = models.OneToOneField("StudentDetail", to_field="id")
    
    正向查询
    stu = models.Student.objects.first()
    stu.detail.email  // 基于学生表detail关联字段的关连查询StudentDetail的email  
    '1@qq'
    
    反向查询(由学生详情表反向查询学生信息表)
    detail = models.StudentDetail.objects.get(id=1)
    detail.student.sname  // 基于student字段的关连查询student的sname  
    
    一对多关联查询:
    前提: 由学生信息表Student 查询班级表 Class,
    cid = models.ForeignKey(to="Class", to_field="id")
    
    正向查询
    stu = models.Student.objects.first()
    stu.cid.cname // 基于学生表Student关联字段cid关连查询Class的cname 
    
    反向查询
    cls = models.Class.objects.first()
    cls.student_set.all() //通过_set魔术方法调用的方式来查询学生表中关联信息
    

    注意:
    _set:提供了对象访问相关联表数据的方法。但这种方法只能是相关类访问定义了关系的类(主键类访问外键类)。
    如果不在外键的字段中设置related_name的话,默认就用表名_set。
    如果设置了related_name=”students”,反向查询时可直接使用students进行反向查询。

    多对多操作
    前提: 由老师表Teacher查询班级表 Class, 建立关系表Teacher2Class
    cid_tid = models.ManyToManyField(to="Class",
                                       through="Teacher2Class",
                                       through_fields=("tid", "cid"))
    
    正向查询
    tea = models.Teacher.objects.first()
    tea.cid_tid.all()
    
    反向查询
    cls = models.Class.objects.first()
    cls..teacher_set.all()
    
    下划线的正确使用

    从上面例子, 得出获取对象数据字段时, 单个的数据对象跨表查询可以用点或者set魔术方法。
    而QuerySet可以使用双下划线“
    _”,例如获取Uhost表中外键关联的project表的project id 和project name,可以这样做:

    >>> host2 = Uhost.objects.all().values(‘ip‘,‘name‘,‘project__id‘,‘project__name‘)
    >>> host2[0]
    {‘ip‘: u‘10.6.13.253‘, ‘project__name‘: u‘CPMS10‘, ‘name‘: u‘dbbackupsyncer2‘, ‘project__id‘: u‘org-81‘}
    

    相关文章

      网友评论

          本文标题:Django 关联模型和关联查询

          本文链接:https://www.haomeiwen.com/subject/ysrneqtx.html