简体   繁体   中英

how do i aggregate on nested embedded object in mongo DB

{
"_id": 1,
"title": {
    header1:{ "name":"A" , age:10, "active":true},
    header2:{ "name":"B" , age:15, "active":false},
    header3:{ "name":"C" , age:20, "active":true},
    header4:{ "name":"D" , age:30, "active":true},
    header5:{ "name":"E" , age:35, "active":false},
    header6:{ "name":"F" , age:40, "active":true},
    header7:{ "name":"G" , age:45, "active":false},
}
}

How can I show only those headers whose active value is False?

  1. $project

    1.1 Convert key-value pair to array via $objectToArray for headers field. 1.2 $filter with $$this.v.active which is false .

  2. $project

    2.1 Convert headers to key-value pair via $arrayToObject and assign to title field.

db.collection.aggregate([
  {
    $project: {
      _id: 1,
      headers: {
        $filter: {
          "input": {
            $objectToArray: "$title"
          },
          "cond": {
            "$eq": [
              "$$this.v.active",
              false
            ]
          }
        }
      }
    }
  },
  {
    $project: {
      _id: 1,
      title: {
        "$arrayToObject": "$headers"
      }
    }
  }
])

Sample Mongo Playground

Query

  • convert to array
  • filter keep only the false active
  • convert back to object

Test code here

aggregate(
[{"$set":
  {"title":
   {"$arrayToObject":
    [{"$filter":
      {"input":{"$objectToArray":"$title"},
       "cond":{"$not":["$$this.v.active"]}}}]}}}])

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM