django 里面的查询函数和查询方式F(),Q()

django model 的查询方式 例如:book.objectc.filter() ,book.objects.get()  括号里的给定条件查询


__exact 精确等于 like ‘aaa’
__iexact 精确等于 忽略大小写 ilike ‘aaa’
__contains 包含 like ‘%aaa%’
__icontains 包含 忽略大小写 ilike ‘%aaa%’,但是对于sqlite来说,contains的作用效果等同于icontains。
__gt 大于 (greater than 的缩写 以下都是缩写)
__gte 大于等于 (greater than and equal)
__lt 小于        (less than)
__lte 小于等于
__in 存在于一个list范围内
__startswith 以…开头
__istartswith 以…开头 忽略大小写
__endswith 以…结尾
__iendswith 以…结尾,忽略大小写
__range 在…范围内
__year 日期字段的年份
__month 日期字段的月份
__day 日期字段的日
__isnull=True/False
__isnull=True 与 __exact=None的区别

F()函数:---- 专门取对象中某列值的操作

F函数相当于直接将原生sql语句交给python去执行,而不是通过model去讲语句转换成sql语句,Q函数也一样

F函数执行时并不向数据库取值,从而可以加大处理效率

链接:https://www.tuicool.com/articles/u6FBRz

Q()函数:---- 对对象的复杂查询

Q对象可以与关键字参数查询一起使用,不过一定要把Q对象放在关键字参数查询的前面

链接:http://www.cnblogs.com/linjiqin/p/3817814.html

你可能感兴趣的:(笔记)