Database
db={searchResults:[{"_id":ObjectId("625ebcabcc03685c273b2363"),score:12,approved:true,"createdAt":ISODate("2022-04-19T13:44:11.781Z"),"updatedAt":ISODate("2022-04-19T13:44:11.781Z")},{"_id":ObjectId("625ebcabcc03685c273b2364"),score:19,approved:true,"createdAt":ISODate("2022-04-19T13:44:11.781Z"),"updatedAt":ISODate("2022-04-19T13:44:11.781Z")},{"_id":ObjectId("625ebcabcc03685c273b2367"),score:23,approved:true,"createdAt":ISODate("2022-04-19T13:44:11.781Z"),"updatedAt":ISODate("2022-04-19T13:44:11.781Z")}],ResourceVote:[{userId:ObjectId("625ebcabcc03685c273b2362"),resourceId:ObjectId("625ebcabcc03685c273b2364"),upDown:"up"},{userId:ObjectId("625ebcabcc03685c273b2362"),resourceId:ObjectId("625ebcabcc03685c273b2367"),upDown:"up"},{userId:ObjectId("625ebcabcc03685c273b2312"),resourceId:ObjectId("625ebcabcc03685c273b2367"),upDown:"up"},{userId:ObjectId("625ebcabcc03685c273b2322"),resourceId:ObjectId("625ebcabcc03685c273b2367"),upDown:"down"},{userId:ObjectId("625ebcabcc03685c273b2352"),resourceId:ObjectId("625ebcabcc03685c273b2367"),upDown:"up"},]}
Query
db.searchResults.aggregate([{$lookup:{from:"ResourceVote",localField:"_id",foreignField:"resourceId",as:"votes"}},{"$addFields":{"votesCount":{$reduce:{input:"$votes",initialValue:0,in:{$add:["$$value",{$cond:[{$eq:["$$this.upDown","up"]},1,-1]}]}}}}},{"$addFields":{"wScore":{$add:[{$multiply:["$votesCount",0.1]},"$score"]}}}])