博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
F查询和Q查询,摘自李文周老师
阅读量:6234 次
发布时间:2019-06-21

本文共 1383 字,大约阅读时间需要 4 分钟。

F查询和Q查询

F查询

在上面所有的例子中,我们构造的过滤器都只是将字段值与某个常量做比较。如果我们要对两个字段的值做比较,那该怎么做呢?

Django 提供 F() 来做这样的比较。F() 的实例可以在查询中引用字段,来比较同一个 model 实例中两个不同字段的值。

示例1:

查询评论数大于收藏数的书籍

from django.db.models import Fmodels.Book.objects.filter(commnet_num__gt=F('keep_num'))

Django 支持 F() 对象之间以及 F() 对象和常数之间的加减乘除和取模的操作。

models.Book.objects.filter(commnet_num__lt=F('keep_num')*2)

修改操作也可以使用F函数,比如将每一本书的价格提高30元

models.Book.objects.all().update(price=F("price")+30)

引申:

如果要修改char字段咋办?

如:把所有书名后面加上(第一版)

>>> from django.db.models.functions import Concat>>> from django.db.models import Value>>> models.Book.objects.all().update(title=Concat(F("title"), Value("("), Value("第一版"), Value(")")))

Q查询

filter() 等方法中的关键字参数查询都是一起进行“AND” 的。 如果你需要执行更复杂的查询(例如OR语句),你可以使用Q对象

示例1:

查询作者名是小仙女或小魔女的

models.Book.objects.filter(Q(authors__name="小仙女")|Q(authors__name="小魔女"))

你可以组合& 和|  操作符以及使用括号进行分组来编写任意复杂的Q 对象。同时,Q 对象可以使用~ 操作符取反,这允许组合正常的查询和取反(NOT) 查询。

示例:查询作者名字是小仙女并且不是2018年出版的书的书名。

>>> models.Book.objects.filter(Q(author__name="小仙女") & ~Q(publish_date__year=2018)).values_list("title")

查询函数可以混合使用Q 对象和关键字参数。所有提供给查询函数的参数(关键字参数或Q 对象)都将"AND”在一起。但是,如果出现Q 对象,它必须位于所有关键字参数的前面。

例如:查询出版年份是2017或2018,书名中带物语的所有书。

>>> models.Book.objects.filter(Q(publish_date__year=2018) | Q(publish_date__year=2017), title__icontains="物语")
,
,
]>

转载于:https://www.cnblogs.com/huge-666/p/9949531.html

你可能感兴趣的文章
封装定制的Kali Live ISO
查看>>
Oracle日常维护脚本
查看>>
Android中Handler引起的内存泄露
查看>>
maven的安装和使用
查看>>
Vue技巧小结(持续更新)
查看>>
Linux下编译软件时指定安装目录的好处
查看>>
java中多线程模拟(多生产,多消费,Lock实现同步锁,替代synchronized同步代码块)...
查看>>
[问题]apparmor 问题导致mysql切换datadir目录失败
查看>>
2012 使用XEvent sqlserver.blocked_process_report检测阻塞
查看>>
菜鸟学C:猜数字
查看>>
网络管理经验谈:网络不通的解决之道
查看>>
认识Microsoft Hyper-V Server
查看>>
ASP.NET中,“没有为该对象定义无参数的构造函数”的错误
查看>>
回收站(recyclebin)引发row cache lock
查看>>
nagios安装配置pnp4nagios-0.6
查看>>
VMware vSphere 5.1 群集深入解析(七)
查看>>
SQL Server 黑盒跟踪 -- 进一步了解sqldiag
查看>>
banner和背景的说明
查看>>
redhat6 + 11G RAC 双节点部署
查看>>
使用Handy Backup 6.2进行数据备份与还原(多图)
查看>>