I have the following categories collection
{
"_id" : ObjectId("5e1d8c3ed06661d2b06a7c46"),
"status" : "active",
"noOfLevels" : 3,
"levels" : [
ObjectId("5e1db2237a265cfe50dfdb18"),
ObjectId("5e1db22b7a265cfe50dfdb19"),
ObjectId("5e1db23b7a265cfe50dfdb1a")
],
"name" : "Fuel",
},
{
"_id" : ObjectId("5e1d8c3ed06661d2b06a7c46"),
"status" : "active",
"noOfLevels" : 3,
"levels" : [
ObjectId("5e1db2237a265cfe50dfdb18"),
ObjectId("5e1db22b7a265cfe50dfdb19"),
ObjectId("5e1db23b7a265cfe50dfdb1a")
],
"name" : "Feeds",
}
In the above collection levels _id has been stored as a reference to populate later.
Level collection has this items:-
{
levelName: { type: String, required: true },
levelDesc: { type: String },
levelNo: { type: Number, required: true },
categoryId: { type: Mongoose.Schema.Types.ObjectId, ref: 'trainingCategories', required: true },
videoId: [{ type: Mongoose.Schema.Types.ObjectId, ref: 'trainingVideoMaster' }],
},
{
levelName: { type: String, required: true },
levelDesc: { type: String },
levelNo: { type: Number, required: true },
categoryId: { type: Mongoose.Schema.Types.ObjectId, ref: 'trainingCategories', required: true },
videoId: [{ type: Mongoose.Schema.Types.ObjectId, ref: 'trainingVideoMaster' }],
}
I am using aggregation and lookup to find items in categories collection, in my final result I need counts for videoIds which is present on each level of the particular categories.
Need final result like this:-
{
name: 'How to save fuel',
catNo: 1,
noOfLevels: 3,
totalVideos: 4
},
{
name: 'Feeds',
catNo: 2,
noOfLevels: 3,
totalVideos: 3
}