【django】关联查询

在人生的道路上,不管是潇洒走一回,或者是千山独行,皆须是自己想走的路,虽然,有的人并不是很快就能找到自己的方向和道路,不过,只要坚持到底,我相信,就一定可以找到自己的路,只要找到路,就不必怕路途遥远了。

导读:本篇文章讲解 【django】关联查询,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

一、关联查询

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

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!