Django查找数据库objects.filter() 和 排序order_by 和 Q()与或非 和 F()属性之间比较 的用法

Posted laomuji

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django查找数据库objects.filter() 和 排序order_by 和 Q()与或非 和 F()属性之间比较 的用法相关的知识,希望对你有一定的参考价值。

objects.filter()

条件选取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 空查询

 

order_by

升序

XXXX.objects.all().order_by(‘id‘)

XXXX.objects.all().filter(client=client_id).order_by(‘check_in‘)

降序

XXXX.objects.all().order_by(‘-id‘)

XXXX.objects.all().filter(client=client_id).order_by(‘-check_in‘)

 

Q()    |或    &与(逗号效果一样)    ~非(不等于)

导入from django.db.models imports Q

XXXX.objects.filter(Q(id__gt=3)|Q(bread__gt=2))

 

F()

导入from django.db.models imports F

查询aaa大于bbb的信息

XXXXX.objects.filter(aaa__gt=F(‘bbb‘))

查询aaa大于bbb两倍的信息

XXXXX.objects.filter(aaa__gt=F(‘bbb‘)*2)

 

以上是关于Django查找数据库objects.filter() 和 排序order_by 和 Q()与或非 和 F()属性之间比较 的用法的主要内容,如果未能解决你的问题,请参考以下文章

Django通过列表中的值从数据库中查找项目?

Django 从模型中过滤:Model.objects.filter(Q())

django ORC模型

python之django的objects.get和objects.filter方法

python之django的objects.get和objects.filter方法

django中的objects.get和objects.filter方法的区别