get
和 filter
都是 Django ORM 中常用的查询方法,它们的返回值都是查询集,但有一些区别。
get
方法:
- 用于查询单个对象,如果查询结果集为空或者返回多个结果,将触发
DoesNotExist
或MultipleObjectsReturned
异常。 - 如果查询结果集为空可以使用
get
方法的第二个参数来设定默认值,例如Model.objects.get(pk=1, default=None)
- 支持链式调用其他查询,例如
Model.objects.get(name='John').movies.all()
filter
方法:
- 用于返回一个查询集,查询集可以包含 0 或多个对象。
- 支持使用多个筛选条件,多个条件默认使用
AND
连接,例如Model.objects.filter(name='John', age=18)
- 支持链式调用其他查询,例如
Model.objects.filter(name='John').order_by('-age')。
以下是使用 get
和 filter
方法的示例:
from myapp.models import Person
# 获取单个对象
person = Person.objects.get(name='John')
print(person)
# 使用 get 方法获取不存在的对象时,捕获 DoesNotExist 异常
try:
person = Person.objects.get(name='Tom')
except Person.DoesNotExist:
print('Person not found')
# 使用 `get` 方法第二个参数设置默认值
person = Person.objects.get(name='Tom', default=None)
if person is None:
print('Person not found')
# 获取查询集,使用 filter 方法
people = Person.objects.filter(age=18)
for person in people:
print(person)
# 使用多个筛选条件
people = Person.objects.filter(name='John', age=18)
for person in people:
print(person)
在以上示例中,我们首先从 myapp.models
中导入了 Person
模型,并使用 get
方法获取了名为 John
的 Person
对象。然后,我们捕获了使用 get
方法获取不存在的对象时触发的 DoesNotExist
异常,并演示了如何使用 get
方法的第二个参数来设置默认值。
接着,我们使用了 filter
方法筛选出年龄为 18 的所有人,并使用 for
循环遍历查询集。
最后,我们使用了 filter
方法的多个筛选条件来获取名为 John
且年龄为 18 的人。