Python Django2 model 查询介绍(条件、范围、模糊查询)


Posted in Python onMarch 16, 2020

条件查询

范围查询

模糊查询

条件查询

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)

以上这篇Python Django2 model 查询介绍(条件、范围、模糊查询)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python continue语句用法实例
Mar 11 Python
在Docker上部署Python的Flask框架的教程
Apr 08 Python
初步剖析C语言编程中的结构体
Jan 16 Python
python+django加载静态网页模板解析
Dec 12 Python
django1.11.1 models 数据库同步方法
May 30 Python
python中使用print输出中文的方法
Jul 16 Python
python中退出多层循环的方法
Nov 27 Python
opencv实现静态手势识别 opencv实现剪刀石头布游戏
Jan 22 Python
OpenCV-Python 摄像头实时检测人脸代码实例
Apr 30 Python
Python 下载及安装详细步骤
Nov 04 Python
python Plotly绘图工具的简单使用
Mar 03 Python
Python爬取网站图片并保存的实现示例
Feb 26 Python
python高阶函数map()和reduce()实例解析
Mar 16 #Python
Django models filter筛选条件详解
Mar 16 #Python
python递归调用中的坑:打印有值, 返回却None
Mar 16 #Python
django 前端页面如何实现显示前N条数据
Mar 16 #Python
Python迭代器Iterable判断方法解析
Mar 16 #Python
python 递归调用返回None的问题及解决方法
Mar 16 #Python
python 通过邮件控制实现远程控制电脑操作
Mar 16 #Python
You might like
ThinkPHP公共配置文件与各自项目中配置文件组合的方法
2014/11/24 PHP
ThinkPHP3.2.2实现持久登录(记住我)功能的方法
2016/05/16 PHP
总结PHP内存释放以及垃圾回收
2018/03/29 PHP
许愿墙中用到的函数
2006/10/07 Javascript
javascript根据像素点取位置示例
2014/01/27 Javascript
轻松使用jQuery双向select控件Bootstrap Dual Listbox
2015/12/13 Javascript
artDialog+plupload实现多文件上传
2016/07/19 Javascript
浅谈JQ中mouseover和mouseenter的区别
2016/09/13 Javascript
前端 Vue.js 和 MVVM 详细介绍
2016/12/29 Javascript
原生Aajax 和jQuery Ajax 写法个人总结
2017/03/24 jQuery
详解如何在Vue2中实现组件props双向绑定
2017/03/29 Javascript
原生JS实现移动端web轮播图详解(结合Tween算法造轮子)
2017/09/10 Javascript
Angular中的$watch方法详解
2017/09/18 Javascript
vue生成token保存在客户端localStorage中的方法
2017/10/25 Javascript
Vue 仿QQ左滑删除组件功能
2018/03/12 Javascript
angular第三方包开发整理(小结)
2018/04/19 Javascript
解决Layui数据表格中checkbox位置不居中的方法
2018/08/15 Javascript
[36:54]Mineski vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
介绍Python中的fabs()方法的使用
2015/05/14 Python
python交互式图形编程实例(三)
2017/11/17 Python
Django Sitemap 站点地图的实现方法
2019/04/29 Python
python同步两个文件夹下的内容
2019/08/29 Python
python实现录屏功能(亲测好用)
2020/03/02 Python
Matplotlib 绘制饼图解决文字重叠的方法
2020/07/24 Python
Python 通过爬虫实现GitHub网页的模拟登录的示例代码
2020/08/17 Python
国际贸易专业个人求职信范文分享
2013/12/14 职场文书
4s店机修工岗位职责
2013/12/20 职场文书
《雪地里的小画家》教学反思
2014/02/22 职场文书
高中毕业生登记表自我鉴定范文
2014/03/18 职场文书
教师专业自荐信
2014/05/31 职场文书
教师党员先进性教育自我剖析材料思想汇报
2014/09/24 职场文书
对外汉语专业大学生职业生涯规划书
2014/10/11 职场文书
2014小学数学教师个人工作总结
2014/12/18 职场文书
幼儿园六一儿童节演讲稿
2015/03/19 职场文书
Mysql数据库手动及定时备份步骤
2021/11/07 MySQL
python神经网络 tf.name_scope 和 tf.variable_scope 的区别
2022/05/04 Python