Python Django2 model 查询介绍(条件、范围、模糊查询)
作者:森林屿麓 发布时间:2023-11-02 15:32:09
条件查询
范围查询
模糊查询
条件查询
all()
返回全部结果集
filter(**kwargs)
返回满足参数定义的结果集 例如
Entry.objects.filter(pub_date__year=2006)
exclude(**kwargs)
返回不满足参数定义的结果集 例如
Entry.objects.exclude(pub_date__year=2006)
链式查询
Entry.objects.filter(...
headline__startswith='What'... )
.exclude(...
pub_date__gte=datetime.date.today()... )
.filter(...
pub_date__gte=datetime.date(2005, 1, 30)... )
也可以这样
q1 = Entry.objects.filter(headline__startswith="What")
q2 = q1.exclude(pub_date__gte=datetime.date.today())
q3 = q1.filter(pub_date__gte=datetime.date.today())
或者
q = Entry.objects.filter(headline__startswith="What")
q = q.filter(pub_date__lte=datetime.date.today())
q = q.exclude(body_text__icontains="food")
get()
filter()返回的是一个结果集,如果你确定你要返回的是一条结果,那么就可以使用get() 例如
Entry.objects.get(pk=1)
get()与filter()区别
get()返回单一的一条记录,返回类型也是一个对象,filter()返回的实际一个结果集,返回类型为列表。
使用get(),如果查询结果为空,将会引起DoesNotExist exception,而filter()将会返回[]
范围查询
Limiting
Entry.objects.all()[:5]
将会返回前5条记录
Entry.objects.all()[5:10]
将会返回5~10条记录
order_by
排序
Entry.objects.order_by('headline')[0]
将会按照'headline'进行排序,然后返回第一条记录
语法:字段 + 两条下划线 + 内置查询字段
lt(lte): 小于(小于等于)
Entry.objects.filter(pub_date__lte='2006-01-01')
等同于
SELECT * FROM ... WHERE pub_date <= '2006-01-01';
gt(gte): 大于(大于等于)
in
Entry.objects.filter(id__in=[1,3])
模糊查询
range
常用来筛选出属于某个连续区间的对象
Entry.objects.filter(id__range=[1,3])
contains
包含‘xxx'(大小写敏感),常用于找出包含某些关键字的对象
Entry.objects.filter(type__name__contains='python')
等同于
SELECT ... WHERE name LIKE '%python%';
类似的有icontains (大小写不敏感)。注意contains是大小写敏感的,icontains是大小写不敏感的。
startswith
以‘xxx'开头(大小写敏感)
Entry.objects.filter(name__startswith='高级')
等同于
SELECT ... WHERE name LIKE '高级%';
类似的有istartswith (大小写不敏感)
endswith
以‘xxx'结尾(大小写敏感)
类似的有iendswith (大小写不敏感)
isnull
可设置为True或者False,用来筛选某字段 为NULL / 不为NULL 的对象
Entry.objects.filter(description__isnull=True)
等同
SELECT ... WHERE description IS NULL;
补充知识:Django filter **conditions多条件多字段过滤筛选数据
Application context 应用场景:
新增的一条数据不能与DB库里有的数据重复或者需要多条件/多字段筛选数据时需要用到 **conditions
conditions ={
'server_ip': ip,
"bk_biz_id": bk_biz_id,
'cron_min': c["cron_min"],
'cron_hour': c["cron_hour"],
'cron_day': c["cron_day"],
'cron_month': c["cron_month"],
'cron_week': c["cron_week"],
'cron_task': c["cron_task"],
"creator": c["user"],
"deleted": 0
}
query_set = CrontabInfo.objects.filter(**conditions)
来源:https://blog.csdn.net/u013967628/article/details/82994906


猜你喜欢
- 遇到的问题网上找了一些代码,都是只能建立一次socket传输一张图片,然后断开重新连重新传。而建立一次socket代价不小,反复建立会非常消
- Python虚拟机注:本篇是根据教程学习记录的笔记,部分内容与教程是相同的,因为转载需要填链接,但是没有,所以填的原创,如果侵权会直接删除。
- 咳咳,大家看看就好了,本人不负责所产生的后果SELECT * FROM `vbb_strikes` WHERE 1 union select
- 提要:作为普通的Python开发者来讲,深入理解object、type不是必要的,但了解他们确实元编程这个词很多朋友都听过,可能用的却不多。
- SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ON GO CREATE function [dbo]
- “/”应用程序中的服务器错误。用户 'jb51net' 登录失败。原因: 该帐户的密码必须更改。说明: 执行当前 Web 请
- 如何要恢复Master数据库呢?方法1:重装SQL,但是数据就Over掉了方法2:重建Master Rebuildm.exe 用到SQL的安
- 本文实例讲述了Go语言接口用法。分享给大家供大家参考。具体分析如下:接口类型是由一组方法定义的集合。接口类型的值可以存放实现这些方法的任何值
- 1、目录操作1.1、获取当前目录# coding:utf-8import os# 获取当前工作目录(绝对路径)print(os.getcwd
- 本文实例为大家分享了Python实现GUI学生信息管理系统的具体代码,供大家参考,具体内容如下项目环境: 软件环境: &
- 目录结构:contents structure [-]在开始文章之前,先贴上一张Iterable、Iterator与Generator之间的
- 如下所示:1.条件判断2.内置函数abs()3.内置模块 math.fabsabs() 与fabs()的区别abs()是一个内置函数,而fa
- 项目场景:使用Anaconda Prompt创建虚拟环境问题描述保存虚拟环境的默认地址是C盘,而我想将下载的虚拟环境保存到我自定义的位置。解
- oracle 11g的监听日志和警告日志都是在/u01/oracle/diag/tnslsnr/oracle/listener目录和/u01
- 学了一个礼拜Python之后写的,代码很粗糙,只是为了完成利用163邮箱远程关电脑功能。直接把代码发上来吧。要执行的话得先安装一些模块,看i
- 1. Scrapy简介Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架。 可以应用在包括数据挖掘,信息处理或存储历史数据等
- 一般情况下,在 golang 中执行一些命令如 git clone,则可以使用 exec.Command 函数func RunCommand
- 大一上学期学习的内容之一,小黑屋比较好玩。1.导入函数库先导入random、time两个函数库的使用来达到随机生成人物、生成人物加载时间的目
- 1. v-model 表单输入绑定使用v-model创建双向数据绑定, 用来监听用户的输入事件以更新数据,并对一些极端场景进行一些特殊处理。
- 这篇文章主要介绍了Python实现word2Vec model过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学