首页 > 其他分享 >Django笔记十四之统计总数、最新纪录和空值判断等功能

Django笔记十四之统计总数、最新纪录和空值判断等功能

时间:2023-04-02 22:14:27浏览次数:63  
标签:返回 Blog name 笔记 Django 空值 objects filter latest

本篇笔记将介绍一些 Django 查询中统计总数、最新纪录和空值判断等功能。

  1. count
  2. in_bulk
  3. latest、earliest
  4. first、last
  5. exists
  6. contains、icontains
  7. gt、gte、lt、lte
  8. startswith、istartswith
  9. 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笔记十四之统计总数、最新纪录和空值判断等功能

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

标签:返回,Blog,name,笔记,Django,空值,objects,filter,latest
From: https://www.cnblogs.com/hunterxiong/p/17281528.html

相关文章

  • Django使用数据库
    一、数据库配置使用前要设置时区TIME_ZONE,TIME_ZONE='UTC'还要注意setting.py配置文件头部的INSTALLED_APPS选项(已安装程序)。确认自建的pollsapp应用已经安装到总项目容器中了。就是添加一句话:‘pollsapp.apps.PollsappConfig’,其中pollsapp是你创建应用的名字,apps表示应......
  • stm32定时器笔记
    参考资料: STM32-定时器详解STM32F103C8T6的学习(5)——定时器TM32定时器之预分频器详解stm32之TIM-基本定时器应用实例(详细)STM32TIM定时时间的计算《STM32单片机应用基础与项目实践》......
  • C++学习笔记
    char和string的区别字符串string:C++string详解,C++字符串详解(biancheng.net)string是字符串类型,是在C的基础上对字符数组做封装,是一个类,有自己的函数,存的是一个完整的字符串,确实是由字符组成的,但不能认为里面是一个个char数据类型组成的。因而单拎出来里面的字符不能认为是cha......
  • Java学习笔记14
    1.Arrays类​ Arrays类包含用于操作数组的各种方法(如排序和搜索)。该类没有构造函数,直接使用类名.方法名()的方法调用需要的方法。常用方法方法作用publicstaticStringtoString(数组)把数组拼接成一个字符串publicstaticintbinarySearch(数组,查找的元素)二......
  • 新概念2册L75笔记(复习一般过去时&系动词:变化)
    L75SOS单词理解语法理解一般过去时功能:发生在过去的事情;礼貌委婉。关键词:过去具体时间(yesterday/ago/last…)课文理解......
  • Django项目的第1个应用
    1.在Django项目中,每一个应用都是一个python包,都用同一个技术规范。Django自带工具startapp,可以自动生成应用的基础目录结构。如:diango-daminstartapppollsapp2.运行后会创建一个pollsapp目录,不同之处是多一个空的views.py文件,存放视图。3.实现网页能看到视图:一是要有内容:在......
  • stm32寄存器笔记
    参考资料:GPIO相关介绍STM32GPIO的配置寄存器(CRL、CRH)快速学习 stm32的寄存器都是32位的。每个GPIO口有7个寄存器来控制。从GPIO的 GPIO_TypeDef 定义中可以看出,分别是:CRL,CRH,IDR,ODR,BSRR,LCKR。 /***@briefGeneralPurposeI/O......
  • 构建之法阅读笔记2
     学习到了单元测试,单元测试是指开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确,使用单元测试是为了证明某段代码的行为确实和开发者所期望的一致,使代码变得更加完美,让自己负责的模块功能定义尽量明确,模块内部的改变不会影响其他模块,而且模块的质量能......
  • AirNet使用笔记4
    1、DBM“航迹与计划相关配置”中“自动相关参数”:“相关最小权重值(含)”:最小就是二次代码,航班号,地址码全部算下来的,例如航班号一致6,二次代码不一致-3,24地址码一致,最终3,满足最小权重;“直接相关权重值(含)”:权重值(含)为12,指仅正值加起来满足12,就相关,不管负值(不同时的负值)。2、DBM“发布......
  • Java学习笔记(十四) maven1
    Maven介绍Maven是apache旗下的一个开源项目,是一款用于管理和构建java项目的工具,基于项目对象模型(POM)的概念,通过一小段信息来管理项目的构建Apache软件基金会,成立于1999年7月,是目前世界上最大的最受欢迎的开源软件基金会,也是一个专门为支持开源项目而生的非营利性......