我在使用嵌入式文档时遇到了奇怪的行为,我不知道是我做错了什么还是一个错误。
这是我的模型:
var mg = require('mongoose')
, S = mg.Schema;
var subject = new S({
name: String
, properties: [{
name: String
, value: String
}]
});
module.exports = mg.model('Subject',subject);
当我尝试添加一个属性时,它会以某种方式转换为"[object Object]"
:
console.log(req.body); // --> { name: 'height', value: 120 }
console.log(typeof req.body); // --> object
ob.Subject.findByIdAndUpdate(req.params.id, {$push: {properties: req.body}}, function(err, doc) {
if(err) throw err;
res.send(doc);
});
返回doc
的是:
{_id: '...', name: 'sss', properties:[ "[object Object]" ]}
我使用 mongo CLI 检查数据库中的文档并将正确的值放入其中。
//the document as seen in mongo CLI:
{
_id: '...', name: 'sss',
properties: [ "[object Object]", {name: "aaa", value: "bar"} ]
}
然后我尝试了这个:
ob.Subject.findById(id, function(err, doc) {
res.send(doc);
}
然后返回的文档是:
{
_id: '...', name: 'sss',
properties:[ "[object Object]", "[object Object]" ]
}
我认为,发生的事情是猫鼬以某种方式将子文档转换为该字符串。此外,我不认为这是我的res.send()
错,因为:
- 我没有使用
toJson
或toObject
明确地,我根本不处理 JSON 转换 res.send()
不是问题,因为即使我util.inspect
的价值 - 它是一样的- 通过猫鼬进行写入和读取时似乎都发生了无效转换
你有没有遇到过类似的行为?有办法解决吗?
我刚开始使用 mongoose,不知道如何回退到 mongodb native 来更新和获取文档并检查这种行为是否仍然存在(我怀疑)。
任何有用的提示表示赞赏:)