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.
$last
Der $last Operator in Amazon DocumentDB wird verwendet, um das letzte Element in einem Array zurückzugeben, das den Abfragekriterien entspricht. Er ist besonders nützlich, um das neueste oder das letzte Element in einem Array abzurufen, das eine bestimmte Bedingung erfüllt.
Parameter
-
expression: Der Ausdruck, der den Array-Elementen entspricht.
Beispiel (MongoDB Shell)
Das folgende Beispiel zeigt die Verwendung des $last Operators in Kombination mit dem $filter Abrufen des letzten Elements aus einem Array, das eine bestimmte Bedingung erfüllt (z. B. ist subject 'science').
Erstellen Sie Beispieldokumente
db.collection.insertMany([ { "_id": 1, "name": "John", "scores": [ { "subject": "math", "score": 82 }, { "subject": "english", "score": 85 }, { "subject": "science", "score": 90 } ] }, { "_id": 2, "name": "Jane", "scores": [ { "subject": "math", "score": 92 }, { "subject": "english", "score": 88 }, { "subject": "science", "score": 87 } ] }, { "_id": 3, "name": "Bob", "scores": [ { "subject": "math", "score": 75 }, { "subject": "english", "score": 80 }, { "subject": "science", "score": 85 } ] } ]);
Beispiel für eine Abfrage
db.collection.aggregate([ { $match: { name: "John" } }, { $project: { name: 1, lastScienceScore: { $last: { $filter: { input: "$scores", as: "score", cond: { $eq: ["$$score.subject", "science"] } } } } } } ]);
Ausgabe
[
{
_id: 1,
name: 'John',
lastScienceScore: { subject: 'science', score: 90 }
}
]
Codebeispiele
Um ein Codebeispiel für die Verwendung des $last Befehls anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten: