Django 查询集的过滤内置条件

Posted 小作一个

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django 查询集的过滤内置条件相关的知识,希望对你有一定的参考价值。

条件选取querySet的时候,filter表示=,exclude表示!=。
querySet.distinct() 去重复
__exact 精确等于 like ‘aaa‘
 __iexact 精确等于 忽略大小写 ilike ‘aaa‘
 __contains 包含 like ‘%aaa%‘
 __icontains 包含 忽略大小写 ilike ‘%aaa%‘,但是对于sqlite来说,contains的作用效果等同于icontains。
__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__in 存在于一个list范围内
__startswith 以...开头
__istartswith 以...开头 忽略大小写
__endswith 以...结尾
__iendswith 以...结尾,忽略大小写
__range 在...范围内
__year 日期字段的年份
__month 日期字段的月份
__day 日期字段的日
__isnull=True/False

例子:
>> 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 = q.filter(pub_date__lte=datetime.date.today())
>>> q = q.exclude(body_text__icontains="food")

即q1.filter(pub_date__gte=datetime.date.today())表示为时间>=now,q1.exclude(pub_date__gte=datetime.date.today())表示为<=now

以上是关于Django 查询集的过滤内置条件的主要内容,如果未能解决你的问题,请参考以下文章

django 查询所有与相关集的过滤?

Django查询集QuerySet及两大特性

有没有办法检查字符串是不是是 django 查询集的有效过滤器?

如何在 django 中过滤查询集的多对多

查询集 QuerySet

Django内置模板标签