在我的MongoDB中,我有一个学生集合,其中有10条记录,字段为name和roll。这个收藏的一个记录是:
{
"_id" : ObjectId("53d9feff55d6b4dd1171dd9e"),
"name" : "Swati",
"roll" : "80",
}
我想检索字段滚动仅为集合中的所有10条记录,因为我们会在传统数据库中使用:
SELECT roll FROM student
我浏览了很多博客,但所有的结果都是一个必须有WHERE子句的查询,例如:
db.students.find({ "roll": { $gt: 70 })
查询等价于:
SELECT * FROM student WHERE roll > 70
我的要求是只找到一个钥匙,不附带任何条件。它的查询操作是什么。
db.<collection>.find({}, {field1: <value>, field2: <value> ...})
在你的例子中,你可以这样做:
db.students.find({}, {"roll":true, "_id":false})
投影
类型中返回哪些字段
匹配的文件。类型的文档为参数
下面的形式:
{ field1: <value>, field2: <value> ... }
<值>可以是以下任意值:
1或true表示在返回文档中包含该字段。
0或false排除该字段。
NOTE
对于_id字段,您不必显式地指定_id: 1到
返回_id字段。find()方法总是返回_id字段
除非指定_id: 0来屏蔽该字段。
阅读更多
不确定这是否回答了问题,但我相信这是值得一提的。
还有一种方法可以选择单个字段(而不是多个),使用db.collection_name.distinct();
例如,db.student.distinct(‘滚’,{});
或者,第二种方法:使用db.collection_name.find().forEach();(此处可串联选择多个字段)
例如,db.collection_name.find () .forEach(函数(c1){打印(c1.roll);});
我认为mattingly890有正确的答案,这里是另一个例子以及模式/命令
db.collection。Find ({}, {your_key:1, _id:0})
> db.mycollection.find().pretty();
{
"_id": ObjectId("54ffca63cea5644e7cda8e1a"),
"host": "google",
"ip": "1.1.192.1"
}
db.mycollection.find({},{ "_id": 0, "host": 1 }).pretty();
db.<collection>.find({}, {field1: <value>, field2: <value> ...})
在你的例子中,你可以这样做:
db.students.find({}, {"roll":true, "_id":false})
投影
类型中返回哪些字段
匹配的文件。类型的文档为参数
下面的形式:
{ field1: <value>, field2: <value> ... }
<值>可以是以下任意值:
1或true表示在返回文档中包含该字段。
0或false排除该字段。
NOTE
对于_id字段,您不必显式地指定_id: 1到
返回_id字段。find()方法总是返回_id字段
除非指定_id: 0来屏蔽该字段。
阅读更多