输入参数
-
get的参数只能是model中定义的哪些字段,只支持严格匹配
-
filter的参数可以是字段也可以是扩展的where查询关键字,如in,like
返回值:
-
get
返回值是一个定义的
model
对象
-
filter
返回值是一个新的
QuerySet
对象,然后可以对QuerySet在进行查询返回新的QuerySet对象,支持链式操作,QuerySet一个集合对象,可使用迭代或者遍历,切片等,但是不等于list类型(是一个object对象集合)
# get输入
u_get = User.objects.get(id=976)
u_get
<User: CHENJ15>
u_get.username
'CHENJ15'
# filter输入
u_get = User.objects.filter(id=976)
# 输出查询集,取值需要遍历,只有一条数据可以使用.first()取值
u_get
<QuerySet [<User: CHENJ15>]>
u_get.first()
<User: CHENJ15>
u_get.first().username
'CHENJ15'
异常:
-
get只有一条记录返回的时候才正常,也就是说明get查询字段必须是主键或者唯一约束的字段。当返回多条记录或者没有找到记录的时候都会抛出异常
-
get方法是从数据库的取得一个匹配的结果,返回一个对象,如果记录不存在的话,它会报错,有多条记录也会报错。
-
filter有没有匹配的记录都可以
-
filter方法是从数据库的取得匹配的结果,返回一个对象列表,如果记录不存在的话,它会返回[]。
另外,filter有缓存数据的功能,第一次查询数据库并生成缓存,下次再调用filter方法的话,直接取得缓存的数据,会get方法每次执行都是直接查询数据库的。