开发环境:Ubuntu16.04+Django 1.11.9+Python2.7
filter返回的QuerySet:
filter返回的是QuerySet,可以切片以及遍历,get则不行.因为get只能获取唯一存在的数据,不存在或者存在多条都会报错.
在没有符合条件的值的时候:
- get会报错
Book matching query does not exist.
- filter则返回一个空列表,并不会报错.
<QuerySet []>`
继续往下执行代码
判断filter是否有值的时候:
book_info = Book.objects.filter(id=book_id, request_type=2)
queryset.exists()
if book_info.exists():
queryset.count==0:
if queryset.count>0:
pass
else:
pass
if queryset:
if queryset:
pass
else:
pass
filter也会有报错的情况:
filter字段类型为int的时候,输入的参数却是str的时候会报错:
invalid literal for int() with base 10: 'Yu'
使用get的时候,错误信息与上面filter一致.
filter字段存在,但是filter不到对应值的时候:
输出为:<QuerySet []>
为空的时候,自然也不能[0],取值.
使用filter作为过滤条件更新数据的时候:
Book.objects.filter(id=book_id, request_type=2).order_by("-time")[0].update(result=note)
会报错:
'Book' object has no attribute 'update'
使用filter不能部分更新,必须更新所有符合条件的.
但是可以使用[0]可以获取符合过滤条件的第一个值,
解决办法,使用save():
book_info = Book.objects.filter(id=book_id, request_type=2).order_by("-time")[0]
book_info.result = note
book_info.save()
filter 字段后常见的
这里是双下划线,__
__gt 大于
__gte 大于等于
__lt 小于
__lte 小于等于
__contains 包含
__icontains 包含 忽略大小写
__startswith 以...开头
__istartswith 以...开头 忽略大小写
__endswith 以...结尾
__iendswith 以...结尾,忽略大小写