这一篇介绍关于范围,日期的筛选

  1. in
  2. range
  3. date
  4. year
  5. week
  6. weekday
  7. quarter
  8. hour

1、in

in 对应于 MySQL 中的 in 操作,可以接受数组、元组等类型数据作为参数:

Blog.objects.filter(id__in=[1,2,3])

对应的 SQL 是:

select * from blog_blog where id in (1,2,3);

字符串也可以作为参数,但是转义后的 SQL 的意思不太一样:


Blog.objects.filter(name__in="abc")

对应的 SQL 为:

select * from blog_blog where name in ('a', 'b', 'c');

in 操作也可以用于子查询动态的获取列表信息:

inner_qs = Blog.objects.filter(name__contains='hunter')
Entry.objects.filter(blog__in=inner_qs)

注意,以上的QuerySet 只在第二步的时候会去查询数据库,其SQL类似于:

select * from blog_entry where blog_id in (select id from blog_blog where name like binary '%hunter%')

在第一条语句中,没有指定字段,所以是默认搜索 id 的值

如果需要搜索其他字段,比如 name,则需要使用 values() 函数或者 values_list 来指定字段:

inner_qs = Blog.objects.filter(name__contains='hunter').values('name')
Entry.objects.filter(blog__name__in=inner_qs)

对应的 SQL 为:

select * from blog_entry where  FROM `blog_entry` INNER JOIN `blog_blog` ON (blog_entry.id = blog_blog.id)
where blog_blog.name in (select name from blog_blog where name like binary '%hunter%')

2、range

range 是在什么范围之内,对应于 SQL 中的 between and

可以作用在 整型和日期类型字段:


Blog.objects.filter(id__range=[1, 10]) Entry.objects.filter(pud_date__range=['2020-01-01', '2023-01-01'])

3、date

获取符合条件的日期,作用在 datetimefield 上,因为 datefield 本身就是日期,所以不需要 __date 开修饰。

假设一个 model 为 TestModel:

class TestModel(models.Model):
created_time = models.DateTimeField()

这个时候我们想要筛选某个日期,则可以如下使用:

TestModel.objects.filter(created_time__date='2022-01-01')

也可以和上一篇笔记中的 大小于结合使用:

TestModel.objects.filter(created_time__date__gte='2022-01-01')

4、year

筛选年份符合的数据,可作用于 datefield 和 datetimefield 上:

Entry.objects.filter(pub_date__year=2022)

对应的 SQL 为:

select * from blog_entry where pub_date between '2022-01-01' and '2022-12-31';

使用大小于操作:

Entry.objects.filter(pub_date__year__gte=2022)

对应的 SQL 是:

select * from blog_entry where pub_date >= '2022-01-01'

同样的,与 year 相对应的 month 和 day 也可以这样使用。

5、week

一年有 52 个周,如果想获取周数为第几个的话,可以如此操作:

Entry.objects.filter(pub_date__week=2)

对应的 SQL 为:

select * from blog_entry where WEEK(pub_date, 3) = 3;

6、weekday

weekday 对应的是 周几,周日是1,周一是2,到周六是 7

比如想找出 Entry 里所有周一的数据:

Entry.objects.filter(pub_date__weekday=2)

或者是想找出 2022年所有周一的数据:

Entry.objects.filter(pub_date__year=2022).filter(pub_date__weekday=2)

7、quarter

quarter 是查询季度数据,一年一共四个季度,1月1日到3月31日,4月1日到6月30日,7月1日到9月30日,10月1日到12月31日

比如查看所有第二季度的数据:

Entry.objects.filter(pub_date__quarter=2)

8、hour

hour 是小时,与上面的用法同:

TestModel.objects.filter(created_time__hour=9)

以上就是本篇笔记全部内容,接下来将介绍 Django 的 model 的聚合 aggregate 的用法。

本文首发于本人微信公众号:Hunter后端

原文链接:Django笔记十五之in查询及date日期相关过滤操作

如果想获取更多相关文章,可扫码关注阅读:

Django笔记十五之in查询及date日期相关过滤操作的更多相关文章

  1. python3.4学习笔记(十五) 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)

    python3.4学习笔记(十五) 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) python print 不换行(在后面加上,end=''),prin ...

  2. (C/C++学习笔记) 十五. 构造数据类型

    十五. 构造数据类型 ● 构造数据类型概念 Structured data types 构造数据类型 结构体(structure), 联合体/共用体 (union), 枚举类型(enumeration ...

  3. NHibernate系列文章二十五:NHibernate查询之Query Over查询(附程序下载)

    摘要 这一篇文章介绍在NHibernate 3.2里引入的Query Over查询,Query Over查询跟Criteria查询类似.首先创建IQueryOver对象,然后通过调用该对象的API函数 ...

  4. python 学习笔记十五 django基础

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  5. MySQL学习笔记十五:优化(2)

    一.数据库性能评测关键指标 1.IOPS:每秒处理的IO请求次数,这跟磁盘硬件相关,DBA不能左右,但推荐使用SSD. 2.QPS:每秒查询次数,可以使用show status或mysqladmin ...

  6. Django(十五)Form组件

    参考博客: https://www.cnblogs.com/haiyan123/p/7778888.html http://www.cnblogs.com/wupeiqi/articles/61441 ...

  7. (转载)西门子PLC学习笔记十五-(数据块及数据访问方式)

    一.数据块 数据块是在S7 CPU的存储器中定义的,用户可以定义多了数据块,但是CPU对数据块数量及数据总量是有限制的. 数据块与临时数据不同,当逻辑块执行结束或数据块关闭,数据块中的数据是会保留住的 ...

  8. Hibernate学习笔记(五)—— Hibernate查询方式

    一.对象图导航查询 对象图导航查询方式是根据已经加载的对象,导航到他的关联对象.它利用类与类之间的关系来查询对象.比如要查找一个联系人对应的客户,就可以由联系人对象自动导航找到联系人所属的客户对象.当 ...

  9. MYSQL进阶学习笔记十五:MySQL 的账号权限赋予!(视频序号:进阶_33,34)

    知识点十六:MySQL的账号权限赋予(33) 一.MySQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你全力以内的事情,不可以越界.比如只允许你执行select操作,那么你就不能执 ...

  10. MySQL高级学习笔记(五):查询截取分析

    文章目录 慢查询日志 是什么 怎么玩 说明 查看是否开启及如何开启 默认 开启 那么开启了慢查询日志后,什么样的SQL才会记录到慢查询日志里面呢? Case 配置版 日志分析工具mysqldumpsl ...

随机推荐

  1. swift 应用内切换语言

    1:在project info中的locations添加需要的语言 2:创建Localizable.strings文件 点击右边的localization勾选需要的语言 3:创建InfoPlist.s ...

  2. zynq 中断

    #include "stdio.h"#include "xparameters.h"#include "xgpiops.h"#include ...

  3. CSS设置边距

    1.内边距 所有的 ​HTML ​元素基本都是以矩形为基础. 每个 HTML 元素周围的矩形空间由三个重要的属性来控制: ​padding(内边距)​ ​margin(外边距)​ ​border(边框 ...

  4. vscode 自用插件

    Auto Rename Tag              自动配对标签,一同更改: 这个还是比较推荐吧,需要修改的时候只用改第一个,闭合的那一头自动跟着修改了. Quokka              ...

  5. js下载流文件

    npm install js-file-download --savenpm install axios --save import axios from "axios"; imp ...

  6. HTTPS的实现原理 ---- 核心 SSL/TLS协议

    是在应用层和 传输层之间 添加的 安全层(SSL/TLS协议) 端口号 :HTTP 默认是 80,HTTPS 默认是 443. URL 前缀 :HTTP 的 URL 前缀是 http://,HTTPS ...

  7. IT工具知识-08:如何使用Openwrt下的SMB服务(第一次使用时)?

    0.背景知识 使用固件:Lean的R20.5.9由flippy打包 需要软件:ssh客户端(我用的xshell),浏览器(最好是chrome内核) 1.使用教程 1.1 注释掉SAMBA模板中的某条指 ...

  8. wrangler 13 mwz 脱浆记录

    100度水泡了1个小时,一点没缩 70度水泡了3个小时,一点没缩 随后绝望,放洗衣机里洗了20min,缩了2cm 想再接再厉,放洗衣机30min,没缩 放外面晾干,看晾干以后多长吧 --------- ...

  9. idea乱码

    第一步:修改intellij idea配置文件: 找到intellij idea安装目录,bin文件夹下面idea64.exe.vmoptions和idea.exe.vmoptions这两个文件,分别 ...

  10. Python之常用数据类型详解

    tuple 元组 1 # 定义 2 temp = (2, ) # 规范定义,单个元素的元组 3 tem = 2, # 可行,但不规范定义 4 tep = () # 空元组 5 6 tp = (1, ' ...