Доступ к свойствам отношений - MongoDb - PullRequest
0 голосов
/ 28 декабря 2018

У меня есть две модели:

const walletSchema = mongoose.Schema({
  title: { type: String, required: true },
  description: { type: String, required: false},
  amountStart: { type: Number, required: true},
  mount: {type: Number, required: false},
  transfers: [{ type: Schema.Types.ObjectId, ref:'Transfers' }],
});

и

const transferSchema = mongoose.Schema({
  mount: { type: Number, required: true },
  category_id: { type: Schema.ObjectId, ref: "Category", required: false },
  description: { type: String, required: false},
  wallet_id: { type: mongoose.Schema.Types.ObjectId, ref:"Wallet", required: true}
});

и я хочу получить монтирование кошелька (amountStart - все монтирование переводов)

но я не уверен, как это сделать, спасибо!

Ответы [ 2 ]

0 голосов
/ 29 декабря 2018
walletSchema.aggregate([
    { "$match": { "_id": <theIdOfYourWallet } },
    { $lookup: {
       from: "transfers",
       localField: "transfers",
       foreignField: "_id",
       as: "transferInformation"
     }},
     { $project: {walletMount: {$sum: "$transferInformation.mount"}, amountStart: "$amountStart", transfers:[{transfer:"$transferInformation"}]}}
   ])
0 голосов
/ 28 декабря 2018

Самый простой способ сделать это - агрегирование.

walletSchema.aggregate([
 // finds your wallet
 {$match : {_id: <theIdOfYourWallet}},
 // splits your array into multiple aggregation documents 
 // (see this for more info: https://stackoverflow.com/questions/34967482/lookup-on-objectids-in-an-array)
 {$unwind: 'transfers'},
 // fetches each transfer document
 { $lookup: {
    from: "transfers",
    localField: "transfers",
    foreignField: "_id",
    as: "transferInformation"
  }},
 // sums the transfers
 { $group:
   {
    _id: { amountStart: $amountStart },
    // not sure if you can access the .mount field directly like this
    totalTransferMount: { $sum: $transferInformation.mount },
    }
 },
 // calculating the total mount of the wallet
 { $project: { walletMount: { $subtract: [ "$_id.amountStart", "$totalTransferMount" ] } } }
])

Я не проверял это, но если вы понимаете каждый шаг, у вас все будет хорошо.

...