Django ORM的get与filter的区别对比

get和filter都是条件查询语句,类似于sql语句的where。查询xx字段为xx。
查询条件不同在于get的查询符合条件的返回模型类的对象符合条件的对象只能为一个,如果符合筛选条件的对象超过了一个或者没有一个都会抛出错误。
filter可以查询多个对象。
例:模型如下表所示
在这里插入图片描述
采用filter查询id大于0的对象,查询id=1的对象均可查到正常的数据
在这里插入图片描述
采用get查询id大于0的对象则无法正常拿到数据(由于返回的对象不是一个),查询id大于1和id=1的则可以正常拿到数据。
在这里插入图片描述
返回结果不同
get返回的是一个model对象。返回模型对象进一步操作的时候则是操作模型表,比如查看某一个字段
直接通过这个模型表.即可获取字段的值。model对象不支持queryst链式操作,比如无法直接order_by等。
filter返回的是一个queryset查询集对象。对QuerySet查询集对象在进行查询返回新的QuerySet对象,支持链式操作。比如查看queryset查询集对象的字段时则继续通过ORM获取,比如通过values获取某字段的值。
例:模型表仍然是上表。
通过get获取id为1的body字段。需要通过模型对象去拿
在这里插入图片描述
通过filter获取id为1的body字段。需要通过查询集对象去拿
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值