我目前发生了一个非常奇怪的猫鼬错误,我不知道导致这个问题的原因。当我调用findOne
方法时,我得到一个有效的实例,只有_id
字段未初始化。当我试图保存该文档中的更改时,它会崩溃
{ [CastError: Cast to ObjectId failed for value "[object Object]" at path "_id"]
message: 'Cast to ObjectId failed for value "[object Object]" at path "_id"',
name: 'CastError',
type: 'ObjectId',
value:
{ from_node_id: 52e10f6acce9daa7f3bf3162,
target_id: 'a' },
path: '_id' }
我有一个简单的模式定义:
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var transitionProbabilitySchema;
transitionProbabilitySchema = new Schema({
_id: {
from_node_id: {type: Schema.Types.ObjectId, ref: "Zone"}
},
value: {
total_transition_count: Number,
probabilities: [
{to_node_id: {type: Schema.Types.ObjectId, ref: "Zone"}},
{probability: Number}
]}
}, {collection: 'transitionProbability'});
module.exports = mongoose.model('transitionProbability', transitionProbabilitySchema);
当我现在打电话
TransitionProbability.findOne({"_id.from_node_id": from_node_id},
function (err, tp) {
if (err) {
handleError('error - tp not found', err, callback);
} else {
// some modification of tp and then save
}
}
Mongoose返回文档,但只初始化_id
。当我尝试保存更改的文档时,整个功能崩溃,而不是之前。我还将文档记录到控制台以验证它只是`_id'田野失踪。
PS:请注意,from_node_id
是从其他查询中提取的,并且是有效的ObjectId
。
有什么想法吗?在此先感谢您的帮助!
编辑:手动设置_id字段似乎也不起作用。更有趣的是:在尝试其他方法时,我认识到findOneAndUpdate
例如确实冻结了整个node.js应用程序,没有任何日志。它只是没有继续。
答案 0 :(得分:0)
编辑:为了您的信息:在没有找到答案的情况下连续两天搜索后,我在Mongoose.js Github上创建了一张可能存在错误的票证,他们确认了我的问题。 According to them it is fixed in the new 4.0.0 release candidate,不建议用于生产用途。实际上解决了我的问题,但是rc1带来了更多问题。
到目前为止我的解决方案:
最后,我对这个错误非常恼火,因为我改变了该表的整个累积,以便_id
没有单独的from_node_id
字段。我现在直接使用from_node_id
作为ID。