相关文章推荐
一身肌肉的剪刀  ·  Amazon.com: COSTWAY ...·  8 月前    · 
贪玩的紫菜  ·  如何使用 Pandas 删除 ...·  11 月前    · 
很酷的南瓜  ·  minio 存储加密-掘金·  1 年前    · 


输入参数

  • 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方法每次执行都是直接查询数据库的。