如何在mongo shell中查看文档字段?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在mongo shell中查看文档字段?相关的知识,希望对你有一定的参考价值。
有没有办法在mongo的shell中找出文档中的字段/键?举个例子,假设我们有一个类似(伪代码)的文档:
"message": "Hello, world",
"from": "hal",
"field": 123
我想在shell中运行一个命令,返回该文档中的字段/键列表。例如,像这样:
> var message = db.messages.findOne()
> message.keys()
... prints out "message, from, field"
谢谢!
答案
更简单:
Object.keys(db.messages.findOne())
另一答案
一个for ... in
循环应该做的伎俩:
> var message = db.messages.findOne();
> for (var key in message)
... print(key);
...
另一答案
其他答案都是正确的。
但是,由于我是全新的,不知道上述命令需要执行的位置和方式:
以下帮助,来自my github 在命令提示符下运行以下命令(cmd for Windows):
// ------------
// start mongo client
mongo
// ------------
// list all databases
show dbs
// NOTE: assume one of the databases is myNewDatabase
// use the 'myNewDatabase' database
use myNewDatabase
// ------------
// show all collections of 'myNewDatabase' database
show collections
// NOTE: assume one of the collections is 'myCollection'
// show all documents of 'myCollection' collection
db.myCollection.find()
// ------------
// field keys
Object.keys(db.myCollection.findOne());
// values
db.myCollection.find().forEach(function(doc)
for (field in doc)
print(doc[field]);
);
// ------------
另一答案
要获取MongoDB中集合中使用的所有字段的列表,这是我发现最直接的方式(您的里程可能会有所不同:)):
使用以下内容创建.js文件:
use yourdbname
mr = db.runCommand(
"mapreduce" : "collectionName",
"map" : function()
for (var key in this) emit(key, null);
,
"reduce" : function(key, stuff) return null; ,
"out": "collectionName" + "_keys"
)
db[mr.result].distinct("_id")
我发现了如何做这个here (GeoffTech blog)
我从shell运行它以在控制台中打印输出
mongo < nameOfYourFile.js
或者将输出转储到文本文件中:
mongo < nameOfYourFile.js > outputDir\nameOfYourOutputFile.txt
我对MongoDb完全不熟悉,所以我希望它确实可以获得所有字段,而不管整个文档的使用情况如何!
(我在Windows 10上使用MongoDb,所以我的控制台可能与你的不同)
以上是关于如何在mongo shell中查看文档字段?的主要内容,如果未能解决你的问题,请参考以下文章
如何在其中一个字段 Mongo Db [重复] 中检索具有最大值的文档
Sails Js - 防止非模型字段保存在 mongo 文档中
mongo中一个文档的字段是list,怎么删除list中的数据