条件选取QuerySet的时候,filter表示=参数可以写查询条件,exclude表示!=,querySet.distinct() 去重复(除了get返回值都是QuerySet,可以继续调用所有函数)
objects.filter()
__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 排序
方法一:
其中,'id’表示升序; '-id’表示降序。升序时可以不写,是默认。
.all()可以省略。 默认查询所有。 可以结合filter等函数一起使用 。
升序
XXX.objects.all().order_by(‘id’)
XXX.objects.all().filter(client=client_id).order_by(‘check_in’)
降序
XXX.objects.all().order_by(’-id’)
XXX.objects.all().filter(client=client_id).order_by(’-check_in’)
也可以多个字段
XXX.objects.all().order_by(’-id’,‘title’)
方法二:Meta选项ordering
model.py
class Track(models.Model):
album = models.ForeignKey(Album, related_name='tracks')
order = models.IntegerField()
title = models.CharField(max_length=100)
duration = models.IntegerField()
is_deleted = models.BooleanField(default=False)
creator = models.CharField(max_length=100, null=True)
class Meta:
db_table = 'track'
ordering = ('-id',)
ordering它是一个字符串的列表或元组。每个字符串是一个字段名,前面带有可选的“-”前缀表示倒序。前面没有“-”的字段表示正序。使用"?"来表示随机排序。
ordering = (’-id’,‘title’)
先按照‘id’倒序排列,再按照‘title’正序排列。
警告
排序并不是没有任何代价的操作。你向ordering属性添加的每个字段都会产生你数据库的开销。
Q() |或 &与(逗号效果一样) ~非(不等于)
导入from django.db.models imports Q
XXX.objects.filter(Q(id__gt=3)|Q(bread__gt=2))
F()
导入from django.db.models imports F
查询aaa大于bbb的信息
XXX.objects.filter(aaa__gt=F(‘bbb’))
查询aaa大于bbb两倍的信息
XXX.objects.filter(aaa__gt=F(‘bbb’)*2)
聚合函数
导入from django.db.models import Sum,Count,Max,Min,Avg
查询所有XXX的数目。
XXX.objects.all().aggregate(Count(‘id’))
查询所有XXX字段的总和
XXX.objects.all().aggregate(Sum(‘字段’))
count函数:返回值是一个数字
统计所有XXX的数目
XXX.objects.count()
统计id大于3的所有XXX的数目
XXX.objects.filter(id__gt=3).count()