这个类型转换错误与_id有什么关系?转换为objecd失败,值“123”;路径" id"'

What's this casting error has to do with _id? "Cast to ObjectId failed for value "123" at path "_id"'

本文关键字:id quot 失败 路径 objecd 错误 类型转换 转换 关系 什么      更新时间:2023-09-26

我正在尝试根据以下模型的查找标准填充数组。

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

填充方法的代码。

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"};

在集合中是这样的:

{ "_id" : { "$oid" : "57f13dd8607efc603a13168f"} , "observationName" : "OBSERVATION_NAME" , "observationPrefixNumber" : "1" , "observationNumbersList" : [ "123"] , "__v" : 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;
   }
});

填充仅在字段引用任何集合时有效。在您的查询中,您填充"observationNumbersList",但在模式中,您只存储字符串。你的模式应该是

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

如果你不使用人口,那么去掉.populate("observationNumbersList")