Abfragen
Abfragen können wir mit der find()
-Methode machen.
Filtern
Wir können der find()
-Methode ein Objekt mit Bedingungen mitgeben, um nach bestimmten Kriterien zu filtern.
AND-Condition
Um eine AND-Condition in unsere Query hinzuzufĂĽgen, mĂĽssen wir unseren Bedingungen mit Kommas trennen.
OR-Condition
Um eine OR-Condition in unsere Query hinzuzufĂĽgen, mĂĽssen wir den $or
-Operator nutzen.
Operatoren
$eq
Vergleicht Werte, die gleich einem angegebenen Wert sind.
$ne
Vergleicht Werte, die nicht gleich einem angegebenen Wert sind.
$gt
Vergleicht Werte, die grösser als ein angegebener Wert sind.
$gte
Vergleicht Werte, die grösser oder gleich einem angegebenen Wert sind.
$lt
Vergleicht Werte, die kleiner als ein angegebener Wert sind.
$lte
Vergleicht Werte, die kleiner oder gleich einem angegebenen Wert sind.
$in
Vergleicht Werte, die einem der in einem Array angegebenen Werte entsprechen.
$nin
Vergleicht Werte, die keinem der in einem Array angegebenen Werte entsprechen.
Verschachtelte Dokumente
Der SchlĂĽssel muss in ""
stehen.
Keys selektieren
Mit einem zweiten Objekt in der find()
-Funktion können wir bestimmen, welche Daten zurückgegeben werden sollen und welche nicht.
Sortieren
Um zu sortieren, nutzen wir die sort()
-Funktion. Dabei steht 1
fĂĽr Ascending und -1
fĂĽr Descending.
NatĂĽrlich kann auch auf mehreren Sortierebenen sortiert werden.
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
[..]
angeordnetJede 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
$match
Filtert Dokumente nach den gegebenen Kriterien.
$group
$group
Gruppiert die Dokumente nach einem Datenfeld . Folgende Aggregationsfunktionen stehen zur VerfĂĽgung:
$avg
$sum
$count
$min
$max
$first
$last
...
$sort
$sort
Sortiert die Dokumente nach dem angegebenen Feld.
$project
$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
$out
Schreibt Dokumente in eine Collection.
$unwind
$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?
Zuletzt aktualisiert