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

$

Der $ Positionsoperator aktualisiert das erste Array-Element, das der Abfragebedingung entspricht. Er dient als Platzhalter für die Position des übereinstimmenden Array-Elements.

Parameter

  • field.$: Das Array-Feld mit dem Positionsoperator zur Aktualisierung des ersten passenden Elements.

Beispiel (MongoDB Shell)

Das folgende Beispiel zeigt, wie der $ Positionsoperator verwendet wird, um ein bestimmtes Array-Element zu aktualisieren.

Erstellen Sie Beispieldokumente

db.inventory.insertMany([ { _id: 1, item: "Widget", quantities: [10, 20, 30] }, { _id: 2, item: "Gadget", quantities: [5, 15, 25] } ]);

Beispiel für eine Abfrage

db.inventory.updateOne( { _id: 1, quantities: 20 }, { $set: { "quantities.$": 22 } } );

Ausgabe

{ "_id" : 1, "item" : "Widget", "quantities" : [ 10, 22, 30 ] }

Codebeispiele

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

Node.js
const { MongoClient } = require('mongodb'); async function updateDocument() { 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('inventory'); await collection.updateOne( { _id: 1, quantities: 20 }, { $set: { "quantities.$": 22 } } ); const updatedDocument = await collection.findOne({ _id: 1 }); console.log(updatedDocument); await client.close(); } updateDocument();
Python
from pymongo import MongoClient def update_document(): 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.inventory collection.update_one( {'_id': 1, 'quantities': 20}, {'$set': {'quantities.$': 22}} ) updated_document = collection.find_one({'_id': 1}) print(updated_document) client.close() update_document()