这个投射错误与_id有什么关系? “转换为ObjectId失败,因为值”123“在路径”_id“处

时间:2016-10-02 16:56:48

标签: javascript node.js mongodb mongoose-schema

我正在尝试基于查找以下模型的标准来填充数组。

function initSchemaAndModel() {
    observationNameAndTypeSchema = new mongoose.Schema({
        observationName:String,
        observationPrefixNumber:String,
        observationNumbersList: [{type:String, unique:true}]
    });

    ObservationNameAndTypeObject = mongoose.model("observation_name_and_type_model", observationNameAndTypeSchema);
}

这是Populate方法的代码。

ObservationNameAndType.getObservationNameAndTypeModel()
    .findOne({observationName: "OBSERVATION_NAME"})
    .populate("observationNumbersList")
    .exec(function (err, observationNameAndTypeMatchedObject) {

        if(err) {
            console.error("error in finding ", err);
            return;
        }
        observationNameAndTypeMatchedObject.observationNumbersList.push(object);
        observationNameAndTypeMatchedObject.save();
    });

我出于某种原因收到此错误。我不明白是什么导致了它。

 { [CastError: Cast to ObjectId failed for value "123" at path "_id"]
  message: 'Cast to ObjectId failed for value "123" at path "_id"',
  name: 'CastError',
  kind: 'ObjectId',
  value: '123',
  path: '_id',
  reason: undefined }

这是我在集合中插入的数据。

{observationName: "OBSERVATION_NAME", observationPrefixNumber: "1", observationNumbersList : "123"};

这就是Collection中的样子:

{ "_id" : { "$oid" : "57f13dd8607efc603a13168f"} , "observationName" : "OBSERVATION_NAME" , "observationPrefixNumber" : "1" , "observationNumbersList" : [ "123"] , "__v" : 0}

2 个答案:

答案 0 :(得分:0)

在引用其他模型之前,您不需要填充子文档

ObservationNameAndType.getObservationNameAndTypeModel()
    .findOne({observationName: "OBSERVATION_NAME"})
    .exec(function (err, observationNameAndTypeMatchedObject) {

        if(err) {
            console.error("error in finding ", err);
            return;
        }
        observationNameAndTypeMatchedObject.observationNumbersList.push(object);
        observationNameAndTypeMatchedObject.save();
    });

如果您只是需要,可以直接使用$push推送

ObservationNameAndType.update({observationName: "OBSERVATION_NAME"}, {$push: {observationNumbersList: object}}, function (err, observationNameAndTypeMatchedObject) {
   if(err) {
      console.error("error in finding ", err);
      return;
   }
});

答案 1 :(得分:0)

仅当字段引用任何集合时,填充才起作用。在查询中,您填充“observationNumbersList”,但在模式中只存储字符串。 您的架构应该是

  observationNameAndTypeSchema = new mongoose.Schema({
        observationName:String,
        observationPrefixNumber:String,
        observationNumbersList: [{type:mongoose.Schema.Types.ObjectId}]
    });

如果您没有使用人口,请删除.populate("observationNumbersList") 来自您的查询。