猫鼬:4.6.6
MongoDB:2.2.11
节点:4.5
仅启用/禁用虚拟填充字段会导致数组子文档在查询结果中显示为null
var someModelSchema = new mongoose.Schema({
name: String
});
mongoose.model('someModel', someModelSchema)
var schema0 = new mongoose.Schema({
name0: String
});
schema0.virtual('detail', {
ref: 'SomeModel',
localField: '_id',
foreignField: '_id',
justOne: true
});
var schema1 = new mongoose.Schema({
name1: String,
list: [schema0],
obj: schema0
});
var schemaMain = new mongoose.Schema({
nestedObj: schema1,
nameMain: String
});
var ModelMain = mongoose.model('ModelMain', schemaMain);
var x = new ModelMain({
nameMain: 'sss',
nestedObj: {
name1: 'name1',
list: [{
name0: 'name0.1'
}],
obj: {
name0: 'name0.1'
}
}
})
x.save().then(function (err, docs) {
ModelMain.find({}, function (err, docs) {
console.log(JSON.stringify(docs, null, 4));
})
})
结果是
{
"_id": "581cbf70d7c120443684a490",
"nameMain": "sss",
"nestedObj": {
"name1": "name1",
"obj": {
"name0": "name0.1",
"_id": "581cbf70d7c120443684a492"
},
"_id": "581cbf70d7c120443684a491",
"list": [
null
]
},
"__v": 0
}
list
属性为空。 如果您注释掉虚拟属性声明,则 list 包含预期的数据,即:
{
"_id": "581cbfdf0700ba445223c848",
"nameMain": "sss",
"nestedObj": {
"name1": "name1",
"obj": {
"name0": "name0.1",
"_id": "581cbfdf0700ba445223c84a"
},
"_id": "581cbfdf0700ba445223c849",
"list": [
{
"name0": "name0.1",
"_id": "581cbfdf0700ba445223c84b"
}
]
},
"__v": 0
}
注释掉 schemas.js 中Schema.prototype.virtual
声明中的 pre-hook 后,此问题不再存在
即使用空的钩子替换了钩子:
this.pre('init', function(next, obj) {
next();
});
问题仍然存在。
如果注释掉,一切都很好。
在 d09c3d677ca4daf087be343af177f05ae2043502 中修复
最有用的评论
在 d09c3d677ca4daf087be343af177f05ae2043502 中修复