如何在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 [重复] 中检索具有最大值的文档

mongo shell,我如何将查询定向到辅助

Sails Js - 防止非模型字段保存在 mongo 文档中

mongo中一个文档的字段是list,怎么删除list中的数据

如何使用 java 驱动程序更新 mongo db 中的文档字段?

java如何实现mongodb中查询指定字段?