Используя следующий MongoDB запрос:Есть ли способ вернуть только некоторые элементы из массива в MongoDB документе
db.StyleHeader.find({ "FlexContent.ExtendedContent" : { "$elemMatch" : { "Defines" : "Old Keywords" } } }, { "FlexContent.ExtendedContent.Defines" : true, "FlexContent.ExtendedContent.Value" : true }).limit(50);
я получаю следующие результаты:
{
"_id" : 1331142,
"FlexContent" : {
"ExtendedContent" : [{
"Defines" : "Content Keywords",
"Value" : "FST-SET, SIZING_CHART-WOMENS_SIZING"
}, {
"Defines" : "Search Keywords",
"Value" : "Closeout, Sale, Tops, T-Shirt, Womens"
}, {
"Defines" : "Exceptions",
"Value" : ""
}, {
"Defines" : "Old Keywords",
"Value" : "1020A20,PRT,SML,Let's,Tour,W.,S9S,T,Shirt,By,Twin,Six,#1C,PRINT,SM,1020A20PRTSML,WEBSORTZ,CAT-TOPS-WOMENS-ALL,1020898ZZ,1010A17ZZ,1020A21ZZ,1020902ZZ,1020904ZZ,CAT-TWINSIX,CAT-GIFTIDEAS,CAT-GIFTS-30,CAT-GIFTS-50,1020903ZZ,CAT-GIFTS-NEW,CAT-TOPS-WOMENS-TSHRT,CAT-GIFTS-HER,CAT-TOPS-TSHIRT,SIZING_CHART-WOMENS_SIZING,CAT-GIFTS-ALL,FST.-SET,FGT.-TSHIRT,CAT-SALE-ALL,CAT-SALE-TOPS,ZKQX,CO_01,DIV_00,CAT1_BA,CAT2_AC"
}, {
"Defines" : "Name",
"Value" : "Let's Tour Women's Short Sleeve T Shirt By Twin Six "
}, {
"Defines" : "Base Item",
"Value" : "1020A20 PRT SML"
}, {
"Defines" : "Price",
"Value" : "21.95"
}, {
"Defines" : "Upsells",
"Value" : "1010A17, 1020898, 1020902, 1020903, 1020904, 1020A21"
}, {
"Defines" : "Default Customization Template",
"Value" : "not applicable"
}, {
"Defines" : "Product Description Style",
"Value" : "None"
}, {
"Defines" : "Promo Search",
"Value" : ""
}, {
"Defines" : "Auto Customization",
"Value" : ""
}]
}
}
мне действительно нужно только ExtendedContent, который определяет «Ключевые слова поиска».
Есть ли способ, чтобы изменить мой запрос так, чтобы результаты выглядит так:
{
"_id" : 1331142,
"FlexContent" : {
"ExtendedContent" : [{
"Defines" : "Search Keywords",
"Value" : "Closeout, Sale, Tops, T-Shirt, Womens"
}]
}
}
Я пытаюсь выяснить структуру запроса первого в MongoVUE, но в конечном счете, это будет сделано с драйвер C#, так что решение в любом случае будет работать для меня.