mongodb基础知识-返回部分字段

    在sql中,我们一般都不提倡select * from xx这种形式,因为这样会返回所有数据,增加服务器负担,一般都需要限定返回哪些字段。在mongodb查询中,我们有时候也需要限制返回哪些字段,这就需要在find语句里面加上projection这个参数. 

    在mongodb中find的语法是find(query, projection),由于mongodb查询语句使用js,我们可以省略find里面的参数,如果需要添加projection的话,两个条件都需要指定。projection的语法是:{field1:<value>,field2:<value>...}。<value>可以是下面任意一种:

  .1或者true 返回该字段--include

  .0或者false 不返回该字段--exclude

  当使用include作为projection的时候,只会返回include中的字段以及_id这个字段;当使用exclude作为projection的时候,除了exculde中的字段不会返回,其余的字段都会返回。

  需要注意一点是:规定一个projection不能既包含include又包含exclude,有一个特殊情况,由于_id默认是返回的,如果include中不想返回_id,可以在include中明确指定_id:0,也只有include里面可以既包含include字段和_id这个exclude字段。

    举例:

    1. 返回name和age两个字段(默认会返回_id)

    db.user.find({}, {"name" : 1, "age" : 1});

    2. 返回name和age两个(显示排除_id字段)

    db.user.find({}, {"name" : 1, "age" : 1, "_id" : 0});

    3. 不返回password字段

    db.user.find({}, {"password" : 0});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值