$arrayToObject - Amazon DocumentDB

Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.

$arrayToObject

L'$arrayToObjectopérateur dans Amazon DocumentDB est l'inverse de l'$objectToArrayopérateur. Il prend un tableau de documents portant une paire clé-valeur et le convertit en un seul document. Cela est particulièrement utile lorsque vous devez reconvertir un tableau de paires clé-valeur en une structure d'objet ou de document.

Paramètres

  • array expression: expression qui se résout en un tableau. Les éléments du tableau doivent être des documents comportant deux champs : k (la clé) et v (la valeur).

Exemple (MongoDB Shell)

L'exemple ci-dessous montre comment $arrayToObject reconvertir un tableau de paires clé-valeur en document.

Création d'exemples de documents

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 } } ]);

Exemple de requête

db.videos.aggregate([ { $project: { name: 1, videos: { $objectToArray: "$inventory" } } }, { $project: { name: 1, inventory: { $arrayToObject: "$videos" } } } ]);

Sortie

{ "_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 } }

Dans cet exemple, l'$objectToArrayopérateur est utilisé pour convertir l'inventoryobjet en un tableau de paires clé-valeur. L'$arrayToObjectopérateur est ensuite utilisé pour reconvertir le tableau en document, rétablissant ainsi la structure de l'objet d'origine.

Exemples de code

Pour afficher un exemple de code d'utilisation de la $arrayToObject commande, choisissez l'onglet correspondant à la langue que vous souhaitez utiliser :

Node.js
const { MongoClient } = require('mongodb'); async function example() { const client = await MongoClient.connect('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false'); const db = client.db('test'); const collection = db.collection('videos'); const result = await collection.aggregate([ { $project: { name: 1, videos: { $objectToArray: '$inventory' } } }, { $project: { name: 1, inventory: { $arrayToObject: '$videos' } } } ]).toArray(); console.log(result); await client.close(); } example();
Python
from pymongo import MongoClient def example(): client = MongoClient('mongodb://<username>:<password>@<cluster-endpoint>:27017/?tls=true&tlsCAFile=global-bundle.pem&replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false') db = client['test'] collection = db['videos'] result = list(collection.aggregate([ { '$project': { 'name': 1, 'videos': { '$objectToArray': '$inventory' } } }, { '$project': { 'name': 1, 'inventory': { '$arrayToObject': '$videos' } } } ])) print(result) client.close() example()