Django中用fliter是查询多条数据,get是获取一条数据。两者返回的数据格式也有一定的差异。
查询时,一条等于条件非常好写,例如写为get(id=1)或者filter(id=1)等,而大于等于,小于等于,IN等条件则要写成其他的方式。以下是查询时所用的条件的一些整理:
__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
要是有多个条件且为“与”,则可以写成”.filter(条件一).filter(条件二)”,以此类推。