欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-03-20 17:29:32
...

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