MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

comment interroger des données dans un tableau de la collection à l'aide de mangouste

utilisez le cadre d'agrégation.$déroulez votre tableau de journaux et appliquez la condition que vous voulez $triez $match, ignorez.ou vous pouvez vérifier $filtre dans $étape de projet, veuillez publier votre sortie attendue, je vais essayer ma main

db.collection.aggregate([{"$unwind" : "$logs"},
{$match : {"$and" :  [{"logs.date" :{$gte : fromDate} },
{"logs.date" :{"$lte" : toDate}}]}},
{"$group" : "_id" : "_id",
"logs" : {"$push" : "$logs"},
"names" :{"$first" : "$name"}
}])

Ou vous pouvez utiliser $filter si vous utilisez mongodb 3.2

{
  $filter: {
     input: logs,
     as: "num",
     cond: { $and: [
        { $gte: [ "$$num.date", fromDate ] },
        { $lte: [ "$$num.date", toDate ] }
      ] }
  }
}