我使用mongo创建了一个本地数据库(实际使用此tutorial)
它有一个名为'simple'的数据库和名为'people'的集合。然后我将每个元素的json导入为
{
"id": 1,
"guid": "1581cfde-f2fc-44f8-8953-511331e943ab",
"isActive": true,
"firstName": "Ilene",
"lastName": "Kent",
"email": "carolegoodman@intrawear.com"
}
然后,我在节点应用程序
中创建架构和Person模型var express = require('express');
var path = require('path');
var mongoose = require('mongoose');
var app = express();
app.set('port', (process.env.PORT || 5000));
mongoose.connect('mongodb://localhost/simple')
var personSchema = {
firstname: String,
lastname: String,
email: String
}
var Person = mongoose.model('Person', personSchema, 'people')
app.get('/users', function(req,res){
Person.find(function(err, doc){
var x = doc[0]
console.log(x)
console.log(Object.keys(x))
res.send(200);
});
});
在Person模型上调用find()时,我得到了记录(对于console.log(doc [0])) - 返回的文档中的第一项:
{ _id: 548e41afa0bad91d53f34cce,
id: 0,
guid: 'af6a931d-1801-4662-9d52-c95dc97bac22',
isActive: false,
firstName: 'Janna',
lastName: 'Shelton',
email: 'crossoconnor@geekology.com' }
但我的问题是,当我在doc [0](即doc [0] .firstName)上查找属性firstName时,我得到一个未定义的。
我已经尝试过诊断这个,而Object.keys(doc [0])给了我:
[ '$__',
'isNew',
'errors',
'_maxListeners',
'_doc',
'_pres',
'_posts',
'save',
'_events' ]
意思是我怀疑当你想要从你返回的元素中访问数据时,必须有一些特殊的mongoose方法 - 但我在文档或这里找不到答案。
由于
答案 0 :(得分:2)
您收到一系列文件。 Mongoose API
doc[0].get('firstName')
答案 1 :(得分:1)
当您只想要一个可以自由操作的文档的简单JavaScript表示时,将lean()
添加到您的Mongoose查询链中:
app.get('/users', function(req,res){
Person.find().lean().exec(function(err, docs){
var x = docs[0]
console.log(x)
console.log(Object.keys(x))
res.send(200);
});
});
答案 2 :(得分:0)
在查询中使用.lean(),如下所示。
db.collection.find().lean().then(function(data){})