Datensätze sortieren
order by
Mit order by
sortieren Sie einen Array aus Datensätzen nach einem bestimmten Feld. Das ist hilfreich, wenn Sie einen Array, bevor Sie ihn weiterverarbeiten, zuerst sortieren möchten.
Wenn Sie order by
in einem Layout-Element Ansicht verwenden, dann wird dieses erst nach einem (ausgewählten) Spaltenkopf sortiert und anschließend über den nach order by
angegebenen Wert.
Beispiel
(select Rechnungen) order by Summe
Ergebnis: Die Einträge der Tabelle Rechnungen werden nach dem Feld Summe sortiert (von klein nach groß).
Beispiel
Sie können die Auswahl der Datensätze mit where
oder eckigen Klammern [...]
einschränken.
Der Wert nach order by
muss dabei nicht zwingend nur ein Feldname sein, Sie können ihn zum Beispiel auch durch Funktionen manipulieren.
(select Rechnungen where Datum = today()) order by number(substr('Rechnungs-Nr.', 3))
Ergebnis: Die Einträge mit heutigem Datum der Tabelle Rechnungen werden nach der Zahl im Text-Feld Rechnungs-Nr. sortiert.
Die 3
verweist auf die Position der Zahl innerhalb der Rechnungs-Nr., die bei uns zum Beispiel an der 4. Stelle beginnt: RE-12574
(0
=R
, 1
=E
, 2
=-
, 3
=1
(die erste Zahl)).
Am besten funktioniert
order by
wenn man Datensätze anhand einer Zahl sortiert.
Tipp: Sortieren von Strings
Vorsicht beim Sortieren von Strings. Strings werden nicht alphabetisch, sondern nach dem Index der Zeichen sortiert. So werden zuerst alle Großbuchstaben alphabetisch sortiert, anschließend die Kleinbuchstaben.
Erläuterung
ABcD wird also zu ABDc sortiert.
Um das gewünschte Ergebnis zu erhalten, vereinheitlichen Sie die Werte einfach durch upper()
oder lower()
. Dann werden die Anfangsbuchstaben zuerst alle einheitlich auf Großbuchstaben bzw. Kleinbuchstaben gesetzt.
Ergebnis: ABcD
Alternative: Verwenden Sie statt order by
die Ninox-Funktion sort()
.
Beispiel
Sie haben eine Tabelle Beispiel für order by mit einem Feld Vornamen. Darin enthalten sind folgende Datensätze: Aaron, Eddi, conrad, beate, Dahlia, and Fatima. Fügen Sie folgendes Skript in ein Formel-Feld ein.
concat(((select 'Beispiel für order by') order by Vorname).Vorname)
Ergebnis: Aaron, Dahlia, Eddi, Fatima, beate, conrad
Das ist nicht die gewünschte alphabetische Sortierung ...
Wir ergänzen upper()
, was alle Einträge zum Sortieren in Großbuchstaben setzt.
concat(((select 'Beispiel für order by') order by upper(Vorname)).Vorname)
Ergebnis: Aaron, beate, conrad, Dahlia, Eddi, Fatima
Brauchen Sie nur die Liste der Namen und nicht die Datensätze selbst, dann empfehlen wir Ihnen die Anwendung von sort()
:
concat(sort((select 'Beispiel für order by').Vorname))
Ergebnis: Aaron, beate, conrad, Dahlia, Eddi, Fatima
Antwort
Content aside
- vor 10 MonatenZuletzt aktiv
- 10Ansichten
-
1
Folge bereits