我试图让 node.js 将表中的数据写入控制台,我的其他表可以工作。
每当我尝试时,我都会得到以下输出:
NO ERROR!
QUERY:{"emitted":{"complete":[[]]},"_events":{}}
我在架构定义中遗漏了什么吗?任何帮助将不胜感激。
- 埃里克
以下内容来自 mongo shell:
> db.userAssessments.find({})
{ "accountId" : "509683edcb884b0000000001", "created" : ISODate("2013-01-12T03:31:20.723Z"), "_id" : ObjectId("50f0d9084469766bb7000001") }
这是我的js:
var userAssessmentsSchema = new mongoose.Schema({
accountId : String,
created : Date,
id: String
});
ANALYZER.userAssessments = mongoose.model('userAssessments', userAssessmentsSchema);
ANALYZER.analyzeAssessment = function() {
var query = ANALYZER.userAssessments.find({}).exec(function(err, ass) {
if (!err) {
console.log("NO ERROR!");
console.log("QUERY:" + JSON.stringify(query));
} else {
console.log("ERROR!");
}
});
};
find
查询的结果将作为第二个参数(代码中的 ass
)传递给 exec
回调。您分配给 query
的返回值是 Promise
从 exec
返回的对象.
更新
你的另一个问题是 Mongoose pluralizes and lower-cases如果您未提供模型名称,则用于派生集合名称。要使其使用 userAssessments
集合而不是 userassessments
,您需要在 mongoose.model
调用中提供该集合名称。
所以你的代码应该是这样的:
ANALYZER.userAssessments = mongoose.model(
'userAssessments', userAssessmentsSchema, 'userAssessments');
ANALYZER.analyzeAssessment = function() {
ANALYZER.userAssessments.find({}).exec(function(err, ass) {
if (!err) {
console.log("NO ERROR!");
console.log("QUERY:" + JSON.stringify(ass));
} else {
console.log("ERROR!");
}
});
};
我是一名优秀的程序员,十分优秀!