Django 关联模型和关联查询

2019-02-17  本文已影响0人  LittleTrue
了解前提:模型的查询对象

三种模型

一对一模型:关系字段定义在任意一端中
一对多模型:关系字段定义在多的一端中;一对多中,外键对应的是主表的一个对象,而不是一个单纯的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‘}
上一篇下一篇

猜你喜欢

热点阅读