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.
$DateDiff
Neu ab Version 5.0
Wird von Elastic Cluster nicht unterstützt.
Der $dateDiff Aggregationsoperator berechnet die Differenz zwischen zwei Daten in angegebenen Einheiten. Er gibt die Anzahl der Einheitengrenzen zurück, die zwischen dem Start- und dem Enddatum überschritten wurden.
Parameter
-
startDate: Der Ausdruck für das Anfangsdatum. -
endDate: Der Ausdruck für das Enddatum. -
unit: Die Zeiteinheit für die Differenz. Unterstützte Einheiten sindyearquarter,month,week,day,hour,minute,second, undmillisecond.
Beispiel (MongoDB Shell)
Das folgende Beispiel zeigt, wie der $dateDiff Operator verwendet wird, um die Anzahl der Tage zwischen Auftragserteilung und Lieferung zu berechnen.
Erstellen Sie Beispieldokumente
db.shipments.insertMany([ { orderId: 1001, orderDate: ISODate("2025-01-10T08:00:00Z"), deliveryDate: ISODate("2025-01-15T14:30:00Z") }, { orderId: 1002, orderDate: ISODate("2025-02-05T10:00:00Z"), deliveryDate: ISODate("2025-02-12T16:45:00Z") } ]);
Beispiel für eine Abfrage
db.shipments.aggregate([ { $project: { orderId: 1, orderDate: 1, deliveryDate: 1, daysToDeliver: { $dateDiff: { startDate: "$orderDate", endDate: "$deliveryDate", unit: "day" } } } } ]);
Ausgabe
[
{
_id: ObjectId('6924a5f2d66dcae121d29517'),
orderId: 1001,
orderDate: ISODate('2025-01-10T08:00:00.000Z'),
deliveryDate: ISODate('2025-01-15T14:30:00.000Z'),
daysToDeliver: 5
},
{
_id: ObjectId('6924a5f2d66dcae121d29518'),
orderId: 1002,
orderDate: ISODate('2025-02-05T10:00:00.000Z'),
deliveryDate: ISODate('2025-02-12T16:45:00.000Z'),
daysToDeliver: 7
}
]
Codebeispiele
Um ein Codebeispiel für die Verwendung des $dateDiff Befehls anzuzeigen, wählen Sie die Registerkarte für die Sprache, die Sie verwenden möchten: