MongoDB - найти количество полей во вложенном документе - PullRequest
1 голос
/ 23 апреля 2020

Я хочу найти количество всех вхождений поля «36» из следующего json: Количество должно быть 2. Поле присутствует в любом из документов data.TL.TXXX. Я попробовал метод find () mongoDB, но одновременно мог искать только в одном документе. Вероятно, мне нужно регулярное выражение здесь. Может ли кто-нибудь помочь мне:

{
    "_id" : ObjectId("1115dd31af82eb3ca8028188"),
    "data" : {
        "TL" : {
            "T001" : {
                "11" : "05012017",
                "13" : "0",
                "28" : "000",
                "29" : "00000",
                "30" : "01012017",
                "31" : "01122014",
                "36" : "10000",
                "37" : "3000",
                "38" : "29.81",
                "39" : "1",
                "44" : "03",
                "02" : "NOT DISCLOSED",
                "04" : "10",
                "05" : "1",
                "08" : "16122014"
            }
        }
    }
},
{
    "_id" : ObjectId("345222ddaf82eb1b262be44f"),
    "data" : {
        "TL" : {
            "T004" : {
                "10" : "19052013",
                "11" : "15062013",
                "12" : "37903",
                "13" : "0",
                "28" : "00000000",
                "29" : "000000000000000000",
                "30" : "01052013",
                "31" : "01062011",
                "44" : "03",
                "02" : "NOT DISCLOSED",
                "04" : "10",
                "05" : "1",
                "08" : "27062011",
                "09" : "08052013"
            },
            "T005" : {
                "11" : "10012017",
                "12" : "114525",
                "13" : "8853",
                "28" : "00000300000300000",
                "29" : "000000XXX0000000010",
                "30" : "01012017",
                "31" : "01022014",
                "36" : "100000",
                "37" : "10000",
                "44" : "03",
                "45" : "6714",
                "02" : "NOT DISCLOSED",
                "04" : "10",
                "05" : "1",
                "08" : "27062011",
                "09" : "12122016"
            },
        }
    }
}

1 Ответ

1 голос
/ 23 апреля 2020

Вы можете использовать ниже агрегации

db.collection.aggregate([
  { $project: { "data.TL": { $objectToArray: "$data.TL" }}},
  { $unwind: "$data.TL" },
  { $project: { data: { $objectToArray: "$data.TL.v" }}},
  { $unwind: "$data" },
  { $group: { _id: "$data.k", count: { $sum: 1 }}}
]);

MongoPlayground

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