Django ORM F对象和Q对象查询

10-14 115阅读 0评论

?=阅读文本前请参考此文章的数据表结构

Django提供了两个非常有用的工具:F对象和Q对象,方便了在一些特殊场景下的查询过程。

1.F对象查询

F对象用于操作数据库中某一列的值,它可以在没有实际访问数据获取数据值的情况下对字段的值进行引用

使用F对象之前需要将它引入当前的环境中:

from django.db.models import F

如果要查询up小于等于down的Comment:

comment = Comment.objecTS.filter(up__lte=F('down'))

要查询所有up值大于down值2倍的Comment对象,可以这样实现:

comment = Comment.objects.filter(up__gt=F('down') * 2)

使用F查询让表中的某个字段值+1:

comment = Comment.objects.Get(ID=1) comment.up = F('up') + 1 comment.save()

2.Q对象查询

使用Q对象之前需要将它引入当前的环境中:

from djanGo.db.models import Q

如果想要查询up大于60或down大于60的所有Comment对象:

comment = Comment.objects.filter(Q(up__gt=60) | Q(down__gt=60))

Q对象也可以与关键字参数组合在一起使用,但是在这种情况下,DjanGO规定,Q对象必须放在前面:

Django ORM F对象和Q对象查询

多个Q对象可以使用“&”(与)、“|”(或)运算符组合,产生一个新的Q对象。可以使用“”(非)运算符取反,即实现not查询❤️

到此这篇关于DjangoORMF对象和Q对象查询的文章就介绍到这了,更多相关DjangoF对象和Q对象查询内容请搜索云初冀北以前的文章或继续浏览下面的相关文章希望大家以后多多支持云初冀北!

免责声明
本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:goliszhou@gmail.com
$

发表评论

表情:
评论列表 (暂无评论,115人围观)

还没有评论,来说两句吧...