在猫鼬中,目前我有2个架构,第一个是产品详细信息,第二个是库存,两个架构都在单独的文件中
ProductDetail架构
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var productDetailSchema = new Schema({
ProductID:{type:String,unique:true, require:true},
ProductName:{type:String, require:true},
Spec:String,
Price:String,
Unit:String,
OwnBrand:Boolean,
Inventory:{ type: Schema.Types.ObjectId, ref: 'inventoryModel'}
}, {collection:'products'});
module.exports = mongoose.model('productDetailModel', productDetailSchema)
库存模式
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var inventorySchema = new Schema({
product:{ type: Schema.Types.ObjectId, ref: 'productDetailModel' },
stockLevel:Number
}, {collection:'inventory'});
module.exports = mongoose.model('inventoryModel', inventorySchema)
在这种情况下,我想将库存stockLevel放入productDetail中。像这样
{
ProductID:'P701',
ProductName:'popcorn',
Spec:'Large Pack',
Price:'10.00',
Unit:'packs'
Inventory: 20
}
因此,我尝试使用猫鼬填充方法
productDetail.findOne({ProductID:'P701'}).populate('Inventory').exec(function(err, doc){
if(err){
console.log(err)
}else{
console.log(doc)
}
})
这是我在“库存收藏”中的数据
{
"_id" : ObjectId("584f663d95dfa29bad337572"),
"ProductID": "P701",
"StockLevel": "20"
}
以及“ ProductDetail集合”中的数据
{
_id : ObjectId("584a3cea027c1f62da941acf"),
ProductID:'P701',
ProductName:'popcorn',
Spec:'Large Pack',
Price:'10.00',
Unit:'packs'
}
出于某种原因,没有出现错误,但console.log(doc)仍然没有包含任何库存:stockLevel。我知道我做错了什么,但我不知道它在哪里。为了使此代码正常工作,我缺少哪种关键概念?先感谢您
您inventory
在中productDetailModel
应该是ObjectId
,根据此处显示的是一个数字(即20)。
{
ProductID:'P701',
ProductName:'popcorn',
Spec:'Large Pack',
Price:'10.00',
Unit:'packs'
Inventory: 20
}
这应该是这样的:
Inventory : ObjectId('someId');
这就是为什么它没有填充的原因,因为它在中找不到ObjectId
20 inventoryModel
。
编辑
该productDetail
文档没有字段为inventory
。因此,它无法填充它。
{
_id : ObjectId("584a3cea027c1f62da941acf"),
ProductID:'P701',
ProductName:'popcorn',
Spec:'Large Pack',
Price:'10.00',
Unit:'packs'
}
它也应该有这样的东西:
inventory : ObjectId("584f663d95dfa29bad337572");//some `ObjectId` which corresponds to `inventoryModel` document.
您需要创建清单field
并在保存productDetail
文档时或在更新文档时将某些清单文档的ObjectId保存在文档中。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句