当前位置: 首页 > news >正文

[Django学习]查询过滤器(lookup types)

1.exact

exact用于精确匹配字段的值。适用于需要精确查找某个字段值的场景。
 

Book.objects.filter(title__exact='Harry Potter')

上面的查询会查找标题完全为“Harry Potter”的书籍。

2.iexact

iexact忽略大小写地精确匹配字段的值。适用于需要忽略大小写进行精确匹配的场景。

Book.objects.filter(title__iexact='harry potter')

这将查找标题在忽略大小写的情况下完全匹配“harry potter”的书籍。

3.contains

contains用于查找字段包含特定子字符串的记录,适用于部分匹配查询。
 

Book.objects.filter(title__contains='Harry')

查找标题包含“Harry”的书籍。

4.icontains

icontains忽略大小写查找字段包含特定子字符串的记录。

Book.objects.filter(title__icontains='harry')

5.startswith

查找以特定字符串开头的记录。
 

Book.objects.filter(title__startswith='Harry')

6.istartswith

忽略大小写

Book.objects.filter(title__istartswith='harry')

7. endswith

endswith用于查找以特定字符串结尾的记录。


8. iendswith

iendswith忽略大小写地查找以特定字符串结尾的记录。


9. in

查找字段值在给定列表中的记录,适用于批量匹配查询(数组)。
 

Book.objects.filter(title__in=['Harry Potter', 'The Hobbit'])

只要标题是在给定的数组中,就会把这条记录拿出来


10. gt

查找字段值大于特定值的记录。
 

Book.objects.filter(price__gt=5)

查找价格严格大于5块钱的书

11. gte

查找字段值大于或等于特定值的记录。
 

12./13. lt/lte

lt用于查找字段值小于/小于等于特定值的记录。
 

14. range

range用于查找字段值在特定范围内的记录。
 

Book.objects.filter(price__range=(1, 10))

查找价格在1到10元的书本,range可以和上文的gt/gte、lt/lte搭配使用,如下

        if datas.get("countFlag") == "on":if datas.get("count") == "1":query &= Q(counts__range=(0, 10))elif datas.get("count") == "2":query &= Q(counts__range=(10, 50))elif datas.get("count") == "3":query &= Q(counts__range=(50, 100))elif datas.get("count") == "4":query &= Q(counts__gte=100)


15. date

date用于精确匹配日期字段的值。
 

Book.objects.filter(publish_date__date='2022-01-01')


16. year

year用于匹配特定年份的日期字段。
 

Book.objects.filter(publish_date__year=2022)


17./18. month/day

用法同上

19. week_day

week_day用于匹配特定星期几的日期字段。注意:1代表星期天,2代表星期一,以此类推。
 

Book.objects.filter(publish_date__week_day=2)

这个语句查询发布日期是在周一的书本

20. isnull

查找字段值为空的记录。如下查找作者字段为空的书籍。
 

Book.objects.filter(author__isnull=True)


21. regex

正则表达式匹配字段值。
 

Book.objects.filter(title__regex=r'^Harry')

查找标题以“Harry”开头的书籍。

22. iregex

iregex忽略大小写地正则表达式匹配字段值。

http://www.lryc.cn/news/379662.html

相关文章:

  • 异步开发的终极答案—协程
  • 构建高效的大数据量延迟任务调度平台
  • Python武器库开发-武器库篇之ThinkPHP 2.x 任意代码执行漏洞(六十三)
  • SQLite数据库(数据库和链表双向转换)
  • React框架的来龙去脉,react的技术原理及技术难点和要点,小白的进阶之路
  • CPU飙升100%怎么办?字节跳动面试官告诉你答案!
  • 物理层(二)
  • C#——文件读取IO操作File类详情
  • 昨天gitee网站访问不了,开始以为电脑哪里有问题了
  • 深入理解适配器模式:Java实现与框架应用
  • 跌倒识别:守护公共安全的AI技术应用场景-免费API调用
  • 算法:渐进记号的含义及时间复杂度计算
  • idea导入文件里面的子模块maven未识别处理解决办法
  • IOS Swift 从入门到精通:协议和扩展
  • Vue插件开发:Vue.js的插件架构允许开发者扩展Vue的核心功能,我们可以探讨如何开发一个Vue插件并与社区分享
  • 学习面向对象前--Java基础练习题
  • 用Python实现抖音新作品监控助手,实时获取博主动态
  • 图像分隔和深度成像技术为什么受市场欢迎-数字孪生技术和物联网智能汽车技术的大爆发?分析一下图像技术的前生后世
  • Redis 内存策略
  • Java小实验————斗地主
  • 【Oracle】Linux 卸载重装 oracle 教程(如何清理干净残留)系统 CentOS7.6
  • web中间件漏洞-Jenkins漏洞-弱口令、反弹shell
  • Linux开发讲课9--- Linux的IPC机制-内存映射(Memory Mapping)
  • Java赋值运算符
  • Qt做群控系统
  • 【专业英语 复习】第10章 Information System
  • 09-axios在Vue中的导入与配置
  • odoo17 小变更4
  • Flink assignTimestampsAndWatermarks 深度解析:时间语义与水印生成
  • C++排序算法——合并有序数组