$multiply - 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.

$multiply

L'$multiplyopérateur dans Amazon DocumentDB est utilisé pour multiplier les valeurs de deux ou plusieurs champs ou expressions. Cet opérateur est particulièrement utile pour effectuer des opérations arithmétiques sur des champs numériques dans des documents. Il peut être utilisé à différentes étapes du pipeline d'agrégation, par exemple $project et $addFields pour créer de nouveaux champs ou modifier des champs existants.

Paramètres

  • expression1: première expression numérique à multiplier.

  • expression2: deuxième expression numérique à multiplier.

  • [expression3, ...]: (facultatif) Expressions numériques supplémentaires à multiplier.

Exemple (MongoDB Shell)

L'exemple suivant montre comment $multiply calculer en bonus_miles multipliant base_miles et bonus_rate pour les clients ayant utilisé une carte de crédit pour le voyage.

Exemples de documents

db.miles.insertMany([ { "_id": 1, "customer_name": "Arnav Desai", "member_since": ISODate("1997-03-01T00:00:00Z"), "base_miles": 2500, "bonus_rate": 1.8, "credit_card": true, "trip_cost": 250 }, { "_id": 2, "customer_name": "Jorge Souza", "member_since": ISODate("2004-01-10T00:00:00Z"), "base_miles": 1890, "bonus_rate": 1.4, "credit_card": true, "trip_cost": 189 }, { "_id": 3, "customer_name": "Saanvi Sarkar", "member_since": ISODate("1999-11-22T00:00:00Z"), "base_miles": 3250, "bonus_rate": 1.8, "credit_card": false, "trip_cost": 325 }, { "_id": 4, "customer_name": "Paulo Santos", "member_since": ISODate("2021-06-19T00:00:00Z"), "base_miles": 2980, "bonus_rate": 1.2, "credit_card": true, "trip_cost": 298 }, { "_id": 5, "customer_name": "Wang Xiulan", "member_since": ISODate("1995-12-04T00:00:00Z"), "base_miles": 1350, "bonus_rate": 1.9, "credit_card": false, "trip_cost": 135 } ]);

Exemple de requête

db.miles.aggregate([ { $match: { credit_card: true } }, { $project: { customer_name: 1, base_miles: 1, bonus_rate:1, credit_card: 1, total_miles: { $multiply: ["$base_miles", "$bonus_rate"] } } } ]);

Sortie

[ { _id: 1, customer_name: 'Arnav Desai', base_miles: 12500, bonus_rate: 1.8, credit_card: true, total_miles: 22500 }, { _id: 3, customer_name: 'Saanvi Sarkar',base_miles: 15200, bonus_rate: 1.8, credit_card: true, total_miles: 27360 }, { _id: 4, customer_name: 'Paulo Santos', base_miles: 3400, bonus_rate: 1.1, credit_card: true, total_miles: 3740 } ]

Exemples de code

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

Node.js
const { MongoClient } = require('mongodb'); async function multiplyBonusMiles() { 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('miles'); const result = await collection.aggregate([ { $match: { credit_card: true } }, { $project: { customer_name: 1, base_miles: 1, bonus_rate: 1, credit_card: 1, total_miles: { $multiply: ["$base_miles", "$bonus_rate"] } } } ]).toArray(); console.log(result); await client.close(); } multiplyBonusMiles();
Python
from pymongo import MongoClient def multiply_bonus_miles(): 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['miles'] result = list(collection.aggregate([ {'$match': {'credit_card': True}}, { '$project': { 'customer_name': 1, 'base_miles': 1, 'bonus_rate': 1, 'credit_card': 1, 'total_miles': { '$multiply': ['$base_miles', '$bonus_rate'] } } } ])) print(result) client.close() multiply_bonus_miles()