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});

猜你喜欢

转载自kibear.iteye.com/blog/2344265
今日推荐