$ bis verdoppeln - Amazon DocumentDB

Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.

$ bis verdoppeln

Neu ab Version 4.0

Der $toDouble Operator in Amazon DocumentDB wird verwendet, um einen Wert in eine 64-Bit-Gleitkommazahl mit doppelter Genauigkeit umzuwandeln. Dies kann nützlich sein, wenn Sie arithmetische Operationen mit Werten durchführen müssen, die ursprünglich nicht in einem numerischen Format vorliegen.

Parameter

<expression>: Der Ausdruck, der in einen doppelten Wert umgewandelt werden soll. Dies kann ein beliebiger gültiger Ausdruck sein, der in einen numerischen Wert, eine Zeichenfolge oder einen booleschen Wert aufgelöst wird.

Beispiel (MongoDB Shell)

Dieses Beispiel zeigt, wie der $toDouble Operator verwendet wird, um einen Zeichenkettenwert in einen numerischen Wert umzuwandeln, um eine mathematische Berechnung durchzuführen.

Erstellen Sie Beispieldokumente

db.numbers.insertMany([ { _id: 1, value: "10.5" }, { _id: 2, value: "20.25" }, { _id: 3, value: "7" } ])

Beispiel für eine Abfrage

db.numbers.aggregate([ { $project: { _id: 1, value: 1, double_value: { $toDouble: "$value" }, double_plus_five: { $add: [{ $toDouble: "$value" }, 5] } } } ])

Ausgabe

[ { "_id" : 1, "value" : "10.5", "double_value" : 10.5, "double_plus_five" : 15.5 }, { "_id" : 2, "value" : "20.25", "double_value" : 20.25, "double_plus_five" : 25.25 }, { "_id" : 3, "value" : "7", "double_value" : 7.0, "double_plus_five" : 12.0 } ]

Codebeispiele

Um ein Codebeispiel für die Verwendung des $toDouble Befehls anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten:

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('numbers'); const result = await collection.aggregate([ { $project: { _id: 1, value: 1, double_value: { $toDouble: "$value" }, double_plus_five: { $add: [{ $toDouble: "$value" }, 5] } } } ]).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['numbers'] result = list(collection.aggregate([ { '$project': { '_id': 1, 'value': 1, 'double_value': { '$toDouble': '$value' }, 'double_plus_five': { '$add': [{ '$toDouble': '$value' }, 5] } } } ])) print(result) client.close() example()