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.
$ Stream ändern
Wird von Elastic Cluster nicht unterstützt.
In der $changeStream Aggregationsphase wird ein Change-Stream-Cursor geöffnet, um Änderungen an einer Sammlung in Echtzeit zu überwachen. Sie gibt Änderungsereignisdokumente zurück, wenn Einfüge-, Aktualisierungs-, Ersetzungs- oder Löschvorgänge ausgeführt werden.
Parameter
-
fullDocument: Gibt an, ob bei Aktualisierungsvorgängen das vollständige Dokument zurückgegeben werden soll. Die Optionen lautendefaultoderupdateLookup. -
resumeAfter: Optional. Setzen Sie das Token fort, um ab einem bestimmten Punkt im Change-Stream fortzufahren. -
startAtOperationTime: Optional. Zeitstempel, ab dem der Change-Stream gestartet werden soll. -
allChangesForCluster: Optional. Boolescher Wert: Wanntrue, überwacht alle Änderungen im gesamten Cluster (für die Admin-Datenbank). Wennfalse(Standard), wird nur die angegebene Sammlung überwacht.
Beispiel (MongoDB Shell)
Das folgende Beispiel zeigt, wie die $changeStream Bühne verwendet wird, um Änderungen an einer Sammlung zu überwachen.
Beispiel für eine Abfrage
// Open change stream first const changeStream = db.inventory.aggregate([ { $changeStream: { fullDocument: "updateLookup" } } ]); // In another session, insert a document db.inventory.insertOne({ _id: 1, item: "Widget", qty: 10 }); // Back in the first session, read the change event if (changeStream.hasNext()) { print(tojson(changeStream.next())); }
Ausgabe
{
_id: { _data: '...' },
operationType: 'insert',
clusterTime: Timestamp(1, 1234567890),
fullDocument: { _id: 1, item: 'Widget', qty: 10 },
ns: { db: 'test', coll: 'inventory' },
documentKey: { _id: 1 }
}
Codebeispiele
Um ein Codebeispiel für die Verwendung der $changeStream Aggregationsphase anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten: