猫鼬查找,然后填充,然后重命名子文档



如何在列表中填充索引,然后重命名其中一个索引?假设我有以下模式的

const supplierSchema = new mongoose.Schema({
name: String,
address: String,
... (19 other fields)
supplier_id: mongoose.Schema.Types.ObjectId,
});
const itemsSchema = new mongoose.Schema({
name: String,
supplier_id: mongoose.Schema.Types.ObjectId,
item_id: mongoose.Schema.Types.ObjectId,
});                                                                                                                                                                                                     
                                                                                                                                                                                                                                                                                                           
const receiptSchema = new mongoose.Schema({
items: [itemSchema]
receipt_id: mongoose.Schema.Types.ObjectId,
});
                                                                                                                                                                                                                                                                                                                                                                                                                                                                    
const Receipt = mongoose.model('Photo', photoSchema);

My Receipt被填充成

Receipt.findById(<insertID>) currently gives:
{
receipt_id: ObjectId("..."),
items: [
{
name: "...",
supplier_id: ObjectId("..."),
item_id: ObjectId("...")
},
{
name: "...",
supplier_id: ObjectId("..."),
item_id: ObjectId("...")
}
],
receipt_id: ObjectId("..."),
}

我希望用nameaddress填充supplier_id。然后将supplier_id重命名为supplier

use aggregate with $lookup

Receipt.aggregate([
{$match  : {_id : <insertID>} },
{
$lookup : {
from: 'supplier',
localField: 'items.supplier_id',
foreignField: '_id',
as: 'supplier'
}
},
{
$unwind : {
path : "supplier"
}
}
])

相关内容

最新更新