find()-Methode machen.
- Funktion
- Output
Filtern
Wir können derfind()-Methode ein Objekt mit Bedingungen mitgeben, um nach bestimmten Kriterien zu filtern.
- Funktion
- Output
AND-Condition
Um eine AND-Condition in unsere Query hinzuzufügen, müssen wir unseren Bedingungen mit Kommas trennen.- Funktion
- Output
OR-Condition
Um eine OR-Condition in unsere Query hinzuzufügen, müssen wir den$or-Operator nutzen.
Operatoren
| Operator | Beschreibung |
|---|---|
ne | Vergleicht Werte, die nicht gleich einem angegebenen Wert sind. |
gte | Vergleicht Werte, die grösser oder gleich einem angegebenen Wert sind. |
lte | Vergleicht Werte, die kleiner oder gleich einem angegebenen Wert sind. |
nin | Vergleicht Werte, die keinem der in einem Array angegebenen Werte entsprechen. |
Verschachtelte Dokumente
- Funktion
- Output
"" stehen.Keys selektieren
Mit einem zweiten Objekt in derfind()-Funktion können wir bestimmen, welche Daten zurückgegeben werden sollen und welche nicht.
- Funktion
- Output
Verschachtelte Felder müssen mit
"" umschlossen sein.Sortieren
Um zu sortieren, nutzen wir diesort()-Funktion. Dabei steht 1 für Ascending und -1 für Descending.
Aggregation
Aggregation ist eine Methode um eine grosse Anzahl verschiedenener Dokumente einer Collection zu bearbeiten und auszuwerten. Eine Aggregation durchläuft eine oder mehrere Stages (Einzeloperationen), mit welchen gefiltert, sortiert, groupiert oder modifiziert werden kann. Der häufigste Anwendungsfall ist die Berechnung von Summen, Durchschnitten, Minium, oder Maximum.Konzept
- Jede Aggregation Pipeline besteht aus mehreren Stages, welche die Dokumente bearbeiten. Die Stages sind ein einem Array
[..]angeordnet - Jede Stage bearbeitet ihre Inputdokumente. Zum Beispiel kann eine Stage Filteroperationen ausführen oder Dokumente gruppieren und bestimmte Werte berechnen.
- Die Output Dokumente einer Stage dienen als Input Dokumente für die nächste Stage. Eine Aggregation Pipeline gleicht daher einer klassischen Unix Pipeline.
- Eine Aggregation Pipeline kann Resultate für Gruppen von Dokumenten zurückliefern, z.B. Anzahl, Summe, Durchschnitt, Minimum und Maximum.
Syntax
Stages
$match
Filtert Dokumente nach den gegebenen Kriterien.
$group
Gruppiert die Dokumente nach einem Datenfeld
. Folgende Aggregationsfunktionen stehen zur Verfügung:
$avg$sum$count$min$max$first$last- …
$sort
Sortiert die Dokumente nach dem angegebenen Feld.
$project
Fügt neue Felder zu den Dokumenten hinzu oder unterdrückt sie:
<field>: 1- übernimmt das angegebene Feld<field>: 0- unterdrückt das angegebene Feld<field>: <expression>- fügt ein Feld hinzu oder ersetzt es
$out
Schreibt Dokumente in eine Collection.
$unwind
Dekonstruiert ein Array-Feld und erstellt für jedes Element im Array ein separates Dokument.
Beispiele
Für wie viele CHF hat jeder Kunde mit dem Status A eingekauft?Wie viele Pizzen mit der Grösse Medium wurden von jeder Sorte bestellt?
Für wie viele Franken wurde zwischen dem 30. Januar 2020 und dem 30. Januar 2020 pro Tag bestellt?