Django ORM中get和filter的区别和使用方法

本文介绍了DjangoORM中的get和filter方法,get用于查询单个对象,可能抛出DoesNotExist或MultipleObjectsReturned异常,而filter返回查询集,支持多个条件查询。示例展示了如何使用这两个方法以及异常处理和默认值设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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 的人。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

湿透剪自布

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值