Удалить дубликаты во вложенной группе - PullRequest
1 голос
/ 14 марта 2020

Я должен удалить элемент, который имеет LocateId для родительского элемента во вложенном массиве и объекте в JSON (я использую MongoDB):

{
 "mainLocation": {
                  "locateId": {"$numberInt": "111111"},
                  "LocateName": "Indonesia",
                  "subLocation": [{
                                "locateId": {"$numberLong": "2222222222"}, *//this the refference for Child location*
                                "LocateName": "Jakarta Pusat",
                                "childLocation": [{
                                                   "locateId": {"$numberLong": "2222222222"},
                                                   *//if the LocateId is same with Sublocation.LocateId will removed*
                                                   "LocateName": "Jakarta Pusat",
                                                 },{
                                                   "locateId": {"$numberLong": "3333333333"},
                                                   "LocateName": "Jakarta Barat",
                                                 }]
                                 },{
                                "locateId": {"$numberLong": "1234123412"},
                                "LocateName": "Bandung",
                                "childLocation": []
                                 }]
                 }
}

и что я ожидается:

{
 "mainLocation": {
                  "locateId": {"$numberInt": "111111"},
                  "LocateName": "Indonesia",
                  "subLocation": [{
                                "locateId": {"$numberLong": "2222222222"},
                                "LocateName": "Jakarta Pusat",
                                "childLocation": [{
                                                   "locateId": {"$numberLong": "3333333333"},
                                                   "LocateName": "Jakarta Barat",
                                                 }] *//the element with same Id has been removed*
                                 },{
                                "locateId": {"$numberLong": "1234123412"},
                                "LocateName": "Bandung",
                                "childLocation": []
                                 }]
                 }
}

, и я попробовал простую функцию, по крайней мере может показать сортировку в порядке, как я ожидал

db.pages.aggregate(
    [{ 
            "$group" : {
                LocatediId: "$mainLocation.LocatediId",
                subLocation : {
                        "$group" : { 
                        LocatediId: "$mainLocation.subLocation.LocatediId",
                        Locatedname: "$mainLocation.subLocation.Locatedname"
                        }}
        }}
    ]);

Так что я могу экспортировать результат в файл JSON .

1 Ответ

1 голос
/ 14 марта 2020

Попробуйте это:

db.collection.aggregate([
   {
      $set: {
         "mainLocation.subLocation": {
            $map: {
               input: "$mainLocation.subLocation",
               as: "subLocation",
               in: {
                  $mergeObjects: [
                     "$$subLocation",
                     {
                        childLocation: {
                           $filter: {
                              input: "$$subLocation.childLocation",
                              cond: { $ne: ["$$this.locateId", "$$subLocation.locateId"] }
                           }
                        }
                     }
                  ]
               }
            }
         }
      }
   }
])

Пн go детская площадка

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...