了解前提:模型的查询对象
三种模型
一对一模型:关系字段定义在任意一端中
一对多模型:关系字段定义在多的一端中;一对多中,外键对应的是主表的一个对象,而不是一个单纯的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‘}