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

$sort

Der $sort Aktualisierungsmodifikator ordnet Array-Elemente an, wenn er zusammen mit dem $push Operator verwendet wird. Er ordnet Array-Elemente auf der Grundlage der angegebenen Feldwerte oder der Elemente selbst in aufsteigender oder absteigender Reihenfolge an.

Parameter

  • field: Das zu ändernde Array-Feld.

  • order: Wird 1 für aufsteigende oder -1 absteigende Reihenfolge verwendet.

Beispiel (MongoDB Shell)

Das folgende Beispiel zeigt, wie der $sort Modifikator mit verwendet wird$push, um neue Quizergebnisse hinzuzufügen und sie in absteigender Reihenfolge zu sortieren.

Erstellen Sie Beispieldokumente

db.students.insertOne({ _id: 1, name: "Bob", quizzes: [ { score: 85, date: "2024-01-15" }, { score: 92, date: "2024-02-10" } ] });

Beispiel für eine Abfrage

db.students.updateOne( { _id: 1 }, { $push: { quizzes: { $each: [{ score: 78, date: "2024-03-05" }], $sort: { score: -1 } } } } )

Ausgabe

{ "_id" : 1, "name" : "Bob", "quizzes" : [ { "score" : 92, "date" : "2024-02-10" }, { "score" : 85, "date" : "2024-01-15" }, { "score" : 78, "date" : "2024-03-05" } ] }

Codebeispiele

Um ein Codebeispiel für die Verwendung des $sort Aktualisierungsmodifikators 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 }, { $push: { quizzes: { $each: [{ score: 78, date: "2024-03-05" }], $sort: { score: -1 } } } } ); 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}, { '$push': { 'quizzes': { '$each': [{'score': 78, 'date': '2024-03-05'}], '$sort': {'score': -1} } } } ) updated_document = collection.find_one({'_id': 1}) print(updated_document) client.close() update_document()