开发者社区> 问答> 正文

queryset的get和filter方法的区别具体是什么呢?

queryset的get和filter方法的区别具体是什么呢?

展开
收起
游客vwuxaq6iqaowc 2021-11-05 18:29:24 508 0
1 条回答
写回答
取消 提交回答
  • 输入参数:

    get的参数只能是model中定义的那些字段,只支持严格匹配

    filter的参数可以是字段,也可以是扩展的where查询关键字,如in,like等

    返回值:

    get返回值是一个定义的model对象

    filter返回值是一个新的QuerySet对象,然后可以对QuerySet在进行查询返回新的QuerySet对象,支持链式操作。QuerySet一个集合对象,可使用迭代或者遍历,切片等,但是不等于list类型

    异常:

    get只有一条记录返回的时候才正常,也就说明get的查询字段必须是主键或者唯一约束的字段。当返回多条记录或者是没有找到记录的时候都会抛出异常。

    filter有没有匹配记录都可以。

    2021-11-05 18:29:38
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载