$[<identifier>] - 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.

$[<identifier>]

Der $[<identifier>] gefilterte Positionsoperator aktualisiert alle Array-Elemente, die den angegebenen Filterbedingungen entsprechen. Er wird mit der arrayFilters Option verwendet, Array-Elemente selektiv zu aktualisieren.

Parameter

  • field.$[identifier]: Das Array-Feld mit dem gefilterten Positionsoperator.

  • arrayFilters: Eine Reihe von Filterbedingungen, die bestimmen, welche Elemente aktualisiert werden sollen.

Beispiel (MongoDB Shell)

Das folgende Beispiel zeigt, wie der $[<identifier>] Operator verwendet wird, um bestimmte Array-Elemente auf der Grundlage einer Bedingung zu aktualisieren.

Erstellen Sie Beispieldokumente

db.students.insertOne({ _id: 1, name: "Alice", grades: [ { subject: "Math", score: 85 }, { subject: "Science", score: 92 }, { subject: "History", score: 78 } ] });

Beispiel für eine Abfrage

db.students.updateOne( { _id: 1 }, { $inc: { "grades.$[elem].score": 5 } }, { arrayFilters: [{ "elem.score": { $gte: 80 } }] } );

Ausgabe

{ "_id" : 1, "name" : "Alice", "grades" : [ { "subject" : "Math", "score" : 90 }, { "subject" : "Science", "score" : 97 }, { "subject" : "History", "score" : 78 } ] }

Codebeispiele

Um ein Codebeispiel für die Verwendung des $[<identifier>] Operators 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('students'); await collection.updateOne( { _id: 1 }, { $inc: { "grades.$[elem].score": 5 } }, { arrayFilters: [{ "elem.score": { $gte: 80 } }] } ); 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.students collection.update_one( {'_id': 1}, {'$inc': {'grades.$[elem].score': 5}}, array_filters=[{'elem.score': {'$gte': 80}}] ) updated_document = collection.find_one({'_id': 1}) print(updated_document) client.close() update_document()