一、关联查询
1、查询影⽚编号为2的所有⼈物信息
由⼀到多的访问语法:
对应的模型类对象.对应的模型类名⼩写_set
f1=FilmInfo.objects.get(fid=2)
f1.peopleinfo_set.all()
<QuerySet [<PeopleInfo: 吴京>, <PeopleInfo: 谢霆锋>]>
新增内容1.1,查询集不能调用peopleinfo_set
1.1、查询影⽚编号为2的所有⼈物信息
f1=FilmInfo.objects.filter(fid=2)
f1.peopleinfo_set.all()
报错:查询集不能调用peopleinfo_set
AttributeError: 'QuerySet' object has no attribute 'peopleinfo_set'
2、查询⼈物编号为1的影⽚信息
由多到⼀的访问语法:
多对应的模型类对象.多对应的模型类中的关系类属性名
p=PeopleInfo.objects.get(uid=1)
p.film
<FilmInfo: django>
3、访问⼀对应的模型类关联对象的id语法:
多对应的模型类对象.关联类属性_id
p=PeopleInfo.objects.get(uid=3)
p.film_id
2
或者是:
p=PeopleInfo.objects.get(uid=3)
p.film.fid
2
二、关联过滤查询
1、由多模型类条件查询⼀模型类数据:
语法如下:
关联模型类名⼩写__属性名__条件运算符=值
注意:如果没有"__运算符"部分,表示等于。
例:查询影⽚信息,要求影⽚⼈物为"吴京"
FilmInfo.objects.filter(peopleinfo__uname='吴京')
<QuerySet [<FilmInfo: 金刚狼>]>
例:查询影⽚信息,要求影⽚中⼈物的描述包含"d"
FilmInfo.objects.filter(peopleinfo__desc__contains='888')
<QuerySet [<FilmInfo: 金刚狼>]>
2、由⼀模型类条件查询多模型类数据:
语法如下:⼀模型类关联属性名__⼀模型类属性名__条件运算符=
例:查询影⽚名为“夺冠”的所有⼈物
PeopleInfo.objects.filter(film__fname='夺冠')
<QuerySet [<PeopleInfo: 巩俐>]>
例:查询影⽚播放量⼤于30的所有⼈物
PeopleInfo.objects.filter(film__playcount__gt=30)
<QuerySet [<PeopleInfo: 吴京>, <PeopleInfo: 谢霆锋>, <PeopleInfo: 巩俐>]>