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});
上一篇: spring mvc 4集成thymeleaf 3
下一篇: mongodb基础知识-修改字段名称