猫鼬填充返回空

木y属

在猫鼬中,目前我有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。我知道我做错了什么,但我不知道它在哪里。为了使此代码正常工作,我缺少哪种关键概念?先感谢您

拉维·香卡·巴尔蒂(Ravi Shankar Bharti)

inventory在中productDetailModel应该是ObjectId,根据此处显示的是一个数字(即20)。

{
    ProductID:'P701',
    ProductName:'popcorn',
    Spec:'Large Pack',
    Price:'10.00',
    Unit:'packs'
    Inventory: 20
}

这应该是这样的:

Inventory : ObjectId('someId');

这就是为什么它没有填充的原因,因为它在中找不到ObjectId20 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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章