Django笔记十四之统计总数、最新纪录和空值判断等功能
本篇笔记将介绍一些 Django 查询中统计总数、最新纪录和空值判断等功能。
- count
- in_bulk
- latest、earliest
- first、last
- exists
- contains、icontains
- gt、gte、lt、lte
- startswith、istartswith
- isnull
1、count
返回查询的 QuerySet 的总数。
比如想查询 Blog 下 name = 'hunter' 的总数:
Blog.objects.filter(name="hunter").count()
返回的结果直接是一个整数,类似的 SQL 代码如下:
select count(*) from blog_blog where name = 'hunter';
2、in_bluk
返回一个 dict,key 为我们指定的字段名的值,value 为这个字段名所在 object 数据。
比如我们需要查询 Blog 这个 model 下 name 为 "hunter", "jack" 的数据,可以如下实现:
Blog.objects.in_bulk(["hunter", "jack"], field_name="name")
返回的数据如下:
{'hunter': <Blog: Blog object (1)>, 'jack': <Blog: Blog object (2)>}
但是需要注意,field_name 这个字段必须有唯一键的约束,即:
class Blog(models.Model):
name = models.CharField(max_length=100, unique=True)
tagline = models.TextField()
不指定 field_name
如果不指定 field_name 的值的话,那么则会默认第一个参数列表的 value 值为 id:
Blog.objects.in_bulk([1, 2])
{1: <Blog: Blog object (1)>, 2: <Blog: Blog object (2)>}
不传参数
如果函数里不传参数,则默认以 field_name="id" 返回所有数据:
Blog.objects.in_bulk()
参数为空
如果函数里的参数为空,则返回空:
Blog.objects.in_bulk([])
3、latest、earliest
latest() 和 earliest() 一样,都是按照指定字段排序后返回最新的,或者最早的一条数据,返回的是 model 的一个实例。
前面介绍在 model 的 Meta 里如果给 get_latest_by 指定了字段,那么 latest() 就可以不加参数,默认按照 get_latest_by 的参数进行排序获取数据。
否则必须在 latest() 里指定字段。
用法如下:
entry_obj = Entry.objects.latest('pub_date)
entry_obj = Entry.objects.latest('pub_date', '-expire_date')
系统会按照 pub_date 字段进行排序,然后返回最近的一条数据。
注意:这个操作和 get() 方法一样,如果表里不存在数据,使用 latest() 函数就会报错。
处理 null 值
不同的数据库对 null 值的处理是不一样的,mysql 对 null 的排序会比非null值更高,
所以,在 mysql 中如果想排除掉 null 值,可以在 filter() 中去除这些数据:
Entry.objects.filter(pub_date__isnull=False).latest('pub_date')
latest() 是返回最新的一条数据
earliest() 则是返回最旧的一条数据。
4、first、last
返回符合条件的第一条数据:
Entry.objects.first()
也可以加上filter 和 排序条件:
entry = Entry.objects.filter(id__gte=12).order_by("pub_date").first()
注意: 如果没有符合条件的数据,返回的结果可能是 None
last() 则是返回最后一条数据。
5、exists
检测数据是否存在,返回布尔型结果。
is_exist = Blog.objects.filter(id=1).exists()
判断某种条件的数据是否存在,可以使用这种方式查询。
查询的结果可以有多个,只要结果数 >= 1,返回即为 True。
6、contains、icontains
contains 意思为包含指定字符串,用法如下:
Blog.objects.filter(name__contains="hunter")
对应的 SQL 为:
select * from blog_blog where name like binary '%hunter%'
因为 MySQL 中的 like 是忽略大小写的,所以通过 like binary 来强制不忽略大小写。
而 icontains 的含义和 contains 一致,不过是忽略大小写的:
Blog.objects.filter(name__icontains="hunter")
上面的语句中,name 字段内容包含 Hunter、HUNTER、hUnTER 等任何中的都可以被匹配上,
对应的 SQL 为:
select * from blog_blog where name like '%hunter%'
7、gt、gte、lt、lte
gt: greater than,大于
gte: greater than or equal to 大于等于
lt: less than 小于
lte: less than or equal to 小于等于
用法示例如下:
Blog.objects.filter(id__gt=12)
对应的 SQL 为:
select * from blog_blog where id > 12
8、startswith、istartswith
startswith 以指定字符串为开头,跟 python 里的用法类似
python 用法:
is_right = "abc".startswth("ab")
返回的 is_right 是一个 布尔型数据,表示是否以什么为开头。
Django 里的用法是:
Blog.objects.filter(name__startswith="hunter")
返回一个 QuerySet,对应的 SQL 是:
select * from blog_blog where name like binary 'hunter%'
startswith 是区分大小写的,istartswith 则是忽略大小写的用法
9、isnull
判断字段值是否为 null。
比如我们要取出 Enyry 表里所有 pub_date 字段为 null 的数据:
Entry.objects.filter(pub_date__isnull=True)
如果是取出所有字段值不为空的数据:
Entry.objects.filter(pub_date__isnull=False)
以上就是本篇笔记全部内容,下一篇笔记将介绍model 查询的范围和日期的筛选功能。
本文首发于本人微信公众号:Hunter后端
原文链接:Django笔记十四之统计总数、最新纪录和空值判断等功能
如果想获取更多相关文章,可扫码关注阅读:

Django笔记十四之统计总数、最新纪录和空值判断等功能的更多相关文章
- python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例
python3.4学习笔记(十四) 网络爬虫实例代码,抓取新浪爱彩双色球开奖数据实例 新浪爱彩双色球开奖数据URL:http://zst.aicai.com/ssq/openInfo/ 最终输出结果格 ...
- 《C++游戏开发》笔记十四 平滑过渡的战争迷雾(二) 实现:真正的迷雾来了
本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9712321 作者:七十一雾央 新浪微博:http:/ ...
- (C/C++学习笔记) 十四. 动态分配
十四. 动态分配 ● C语言实现动态数组 C语言实现动态数组,克服静态数组大小固定的缺陷 C语言中,数组长度必须在创建数组时指定,并且只能是一个常数,不能是变量.一旦定义了一个数组,系统将为它分配一个 ...
- TCP/IP详解 笔记十四
TCP/IP协议(二) 连接的建立与终止 tcpdump -S输出TCP报文的格式 格式: 源>目的:标志 (标志就是tcp头部).标识首字符意义如下: 例如:telnet 某服务的输出(包括 ...
- MYSQL进阶学习笔记十四:MySQL 应用程序优化!(视频序号:进阶_32)
知识点十五:MySQL 的应用程序优化(32) 一.访问数据库采用连接池 把连接当做对象或设备,统一放在‘连接池’里.凡是需要访问数据库的地方都从连接池里取连接 二.采用缓存减少对于MySQL的访问: ...
- SharpGL学习笔记(十四) 材质:十二个材质球
材质颜色 OpenGL用材料对光的红.绿.蓝三原色的反射率来近似定义材料的颜色.象光源一样,材料颜色也分成环境.漫反射和镜面反射成分,它们决定了材料对环境光.漫反射光和镜面反射光的反射程度.在进行光照 ...
- 【转】angular学习笔记(十四)-$watch(1)
本篇主要介绍$watch的基本概念: $watch是所有控制器的$scope中内置的方法: $scope.$watch(watchObj,watchCallback,ifDeep) watchObj: ...
- How tomcat works 读书笔记十四 服务器组件和服务组件
之前的项目还是有些问题的,例如 1 只能有一个连接器,只能处理http请求,无法添加另外一个连接器用来处理https. 2 对容器的关闭只能是粗暴的关闭Bootstrap. 服务器组件 org.apa ...
- Django(十四)分页器(paginator)及自定义分页D
http://www.mamicode.com/info-detail-1724597.html http://www.cnblogs.com/wupeiqi/articles/5246483.htm ...
- SpringBoot笔记十四:消息队列
目录 什么是消息队列 消息队列的作用 异步通信 应用解耦 流量削峰 RabbitMQ RabbitMQ流程简介 RabbitMQ的三种模式 安装RabbitMQ RabbitMQ交换器路由和队列的创建 ...
随机推荐
- Optional类与使用==判断null有什么区别?使用Optional类有什么优势?
1.使用object==null的例子 2.null带来的问题 3.其他语言中null的处理(替代) 4.Java8的Optional类 4.1 这样做有什么好处呢? 4.2 引入Optional类的 ...
- Visual Studio快速清除程序中的空行 删除空行
Ctrl+H; 正则替换 ^(?([^\r\n])\s)*\r?$\r?\n 快速删除多个空行
- IOS文件下载时,文件名的处理
string contentType = MimeMapping.GetMimeMapping(name);var isIOS = false; if (Request.UserAgent != nu ...
- Python MySQLdb连接被多线程共享引发的内核segfault段错误
Python celery Worker exited prematurely: signal 11 (SIGSEGV) --一种解决方案 Python libmysqlclient segfault ...
- 关于JSP无法使用静态引用的问题案例
问题描述: 在写项目时,对于头部信息,尾部信息,分页信息等出现频率高,又很雷同的部分进行抽取时,使用到了jsp的静态引用功能,但之前我每次使用,都会导致程序报错,甚至出现tomcat无法正常启动的情况 ...
- Spring源码分析之getBean
一.前言 spring作为JAVAEE最核心的框架,是每一个java开发者所必须掌握的,非常重要,本篇从一个简单例子入手,由浅入深的分析spring创建bean的全过程,目标在于彻底搞懂spring原 ...
- superset连接mysql数据
目前superset的官网没给出windows的安装教程,但是实际操作是可以的,网上有很多教程,再次就不赘述! 本篇随笔是介绍superset如何连接mysql数据源,本人踩坑踩了一整天.=_= ~~ ...
- Android笔记--外部存储空间
存储文件的操作 外部存储空间 私有存储空间和公共存储空间 外部存储空间分为私有+公有 保存文件到外部存储空间的相关代码操作: 私有空间: 公有空间: 记得增加权限(Android_Manifest.x ...
- Python--相关环境的安装,以及hello world的实现
相关环境 进入官网:https://www.python.org/downloads/ 点击这里: 来到新的界面之后,向下滑动: 找到上图中的界面,选择版本进行下载即可. 具体的安装步骤可以参考这里看 ...
- 思必驰周强:AI 和传统信号技术在实时音频通话中的应用
如何用 AI 解决声音传输&处理中的三大问题?三大问题又是哪三大问题? 在「RTE2022 实时互联网大会」中,思必驰研发总监 @周强以<AI 和传统信号技术在实时音频通话中的应用> ...