字段查找是指定SQL WHERE子句的核心内容的方式。
它们被指定为QuerySet方法filter()、exclude()和get()的关键字参数。
1、exact:精确查找。如果为比较提供的值为None,则会将其解释为SQL NULL
在MySQL中,数据库表的“排序”设置决定了精确的比较是否区分大小写。这是一个数据库设置,而不是Django设置。
可以将MySQL表配置为使用区分大小写的比较。
data:image/s3,"s3://crabby-images/a9a69/a9a69d35a24498a96e48b7aaf9b87d803c0fc167" alt=""
2、iexact:不区分大小写的精确查找
data:image/s3,"s3://crabby-images/4ea11/4ea11781527f2ec7440501a988460c266ff5db88" alt=""
3、contains:包含,模糊查询
data:image/s3,"s3://crabby-images/a1cb6/a1cb659b3c96d2c833217966e968d23fea639c38" alt=""
4、icontains:包含,不区分大小写
data:image/s3,"s3://crabby-images/5b7dd/5b7dde40530e5fda9fe622bcc15ff8542b8f4daa" alt=""
5、in:范围查询
data:image/s3,"s3://crabby-images/6158c/6158c956f94822c1f5e232f393264cdb3f004dc2" alt=""
也可以判定结果集,子查询
data:image/s3,"s3://crabby-images/c81d9/c81d9b6ffea38943005ba43b1158c466d851d3b5" alt=""
如果将由values()或values_list()生成的QuerySet作为值传递给__in查找,则需要确保只提取结果中的一个字段。
data:image/s3,"s3://crabby-images/df9b8/df9b85152881053d1140b0ac4e704c5648277dbb" alt=""
6、gt:大于;
gte:大于等于
lt:小于
lte:小于等于
data:image/s3,"s3://crabby-images/66533/66533fceb5a6190e8b0a28e6e3970be8c97db28b" alt=""
7、startswith:区分大小写的开始。
istartswith:不区分大小写
data:image/s3,"s3://crabby-images/72336/723363b351c50cf6a0ed1c438c20836b990de48c" alt=""
8、endswith:区分大小写结尾
iendswith:不区分大小写
data:image/s3,"s3://crabby-images/33cf9/33cf9d9e919f16b945d7707e0599ecced4181530" alt=""
9、range:范围
在SQL中,您可以在任何地方使用range——日期、数字甚至字符。
data:image/s3,"s3://crabby-images/63bed/63bed05c7702c288be941eb36f9762a8313668eb" alt=""
10、date,year,month,day,weak
data:image/s3,"s3://crabby-images/4924f/4924f571b262126742c779723d0509e22cfd11f9" alt=""
11、weekday:取一个整数值,表示从1(星期日)到7(星期六)的星期几。
data:image/s3,"s3://crabby-images/749f2/749f2127131c9ceacaae26ef0ea50c34106e9c44" alt=""
12、quarter:季度。对于日期和日期时间字段,匹配一个“季度”。允许链接额外的字段查找。取1到4之间的整数值,表示该年度的季度。
Entry.objects.filter(pub_date__quarter=2)
13、time:时间
data:image/s3,"s3://crabby-images/e302f/e302f9dd6f20b52b4762b3e781357a99489cce47" alt=""
14、hour:小时。对于日期时间和时间字段,一个精确的小时匹配。允许链接额外的字段查找。取0到23之间的整数。
minute:分钟。0-59
second:秒。0-59
data:image/s3,"s3://crabby-images/983fd/983fd5d20acb4412f2240df6519dd9ed2225f36f" alt=""
15、isnull:是否为空,对应SQL的IS NULL 和IS NOT NULL
data:image/s3,"s3://crabby-images/18210/182102da668c39143c5abcb3c1257c2f06f25986" alt=""
16、regex:正则匹配
iregex:不区分大小写的正则表达式
data:image/s3,"s3://crabby-images/60c75/60c75ff7c24992bcfdcf77a2fab3201f9da8eab2" alt=""
网友评论