一、关联查询
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: 巩俐>]>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123494.html