我正在尝试基于查找以下模型的标准来填充数组。
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}
答案 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")
来自您的查询。