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

本文介绍MongoDB中如何通过find语句中的projection参数来精确控制查询结果返回的字段,包括只返回指定字段、排除特定字段等操作,并给出具体的使用示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值