As traduções são geradas por tradução automática. Em caso de conflito entre o conteúdo da tradução e da versão original em inglês, a versão em inglês prevalecerá.
$objectToArray
O operador $objectToArray de agregação no Amazon DocumentDB converte um objeto (ou documento) em uma matriz. A entrada para o operador é um documento e a saída consiste em um elemento de matriz para cada par de valores de campo no documento de entrada. Esse operador é útil quando você precisa trabalhar com os campos individuais de um documento como uma matriz, como quando você deseja encontrar o documento com o valor máximo ou mínimo para um campo específico.
Parâmetros
-
expression: a expressão do documento a ser convertida em uma matriz.
Exemplo (MongoDB Shell)
O exemplo a seguir demonstra como usar o $objectToArray operador para encontrar o documento com o estoque máximo de uma rede de locadoras de vídeo.
Crie documentos de amostra
db.videos.insertMany([ { "_id": 1, "name": "Live Soft", "inventory": { "Des Moines": 1000, "Ames": 500 } }, { "_id": 2, "name": "Top Pilot", "inventory": { "Mason City": 250, "Des Moines": 1000 } }, { "_id": 3, "name": "Romancing the Rock", "inventory": { "Mason City": 250, "Ames": 500 } }, { "_id": 4, "name": "Bravemind", "inventory": { "Mason City": 250, "Des Moines": 1000, "Ames": 500 } } ]);
Exemplo de consulta
db.videos.aggregate([ { $project: { name: 1, videos: { $objectToArray: "$inventory" } } }, { $unwind: "$videos" }, { $group: { _id: "$name", maxInventory: { $max: "$videos.v" } } } ]);
Saída
[
{
"_id": "Bravemind",
"maxInventory": 1000
},
{
"_id": "Live Soft",
"maxInventory": 1000
},
{
"_id": "Romancing the Rock",
"maxInventory": 500
},
{
"_id": "Top Pilot",
"maxInventory": 1000
}
]
Exemplos de código
Para ver um exemplo de código para usar o $objectToArray comando, escolha a guia do idioma que você deseja usar: