AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL: Reihenfolge von Strings eines Feldes sortieren?

SQL: Reihenfolge von Strings eines Feldes sortieren?

Ein Thema von erich.wanker · begonnen am 9. Mär 2016 · letzter Beitrag vom 10. Mär 2016
Antwort Antwort
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
453 Beiträge
 
Delphi XE4 Professional
 
#1

SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 9. Mär 2016, 16:15
Datenbank: Firebird • Version: 2.5 • Zugriff über: Zeosib 7
Hallo Leute,
ich habe eine Frage:

In einer DBCombobox habe ich folgende Werte zur Auswahl:

JAENNER
FEBRUAR
MAERZ
APRIL
MAI
JUNI
JULI
AUGUST
SEPTEMBER
OKTOBER
NOVEMBER
DEZEMBER

Wenn ich nun die Spalte "Verrechnungsmonat" in einem DBGrid anklicke - bekomme ich folgende (alphabetisch aufsteigende) Reihenfolge:

April
August
Dezember
Februar
...

Wie schaffe ich es (..ohne Hilfsfeld Integer), das die Monate richtig aufsteigend dargestellt werden?

JAENNER
FEBRUAR
MAERZ
..
..



Viele Dank für Hinweise

LiGrü
Erich
Erich Wanker - for life:=1971 to lebensende do begin ..
O
/H\
/ \
  Mit Zitat antworten Zitat
HolgerX

Registriert seit: 10. Apr 2006
Ort: Leverkusen
961 Beiträge
 
Delphi 6 Professional
 
#2

AW: SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 9. Mär 2016, 16:25
Hmm..

wenn der Verrechnungsmonat in der DB ein String (Varchar) ist, und Du 'order by' verwendest..

.. dann gar nicht!

Woher soll die Datenbank bei 'strings' wissen, das es Monate sind.

Generell sollten die Monate in der Datenbank immer als das gespeichert werden, was sie sind: Eine Zahl (1-12).

Für die Visualisierung werden dann die Zahlen in den Monats-String Konvertiert, so dass Du auch in anderen Sprachen immer die Richtige Monatsbezeichnung hast.

Sonnst hättest Du mal 'JAENNER' und mal 'JANUAR' für den selben Monat in der DB stehen
  Mit Zitat antworten Zitat
.Phil

Registriert seit: 19. Sep 2012
5 Beiträge
 
Turbo Delphi für Win32
 
#3

AW: SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 9. Mär 2016, 16:33
Code:
ORDER BY CASE MONAT WHEN 'JÄNNER' THEN 1 WHEN 'FEBRUAR' THEN 2 WHEN 'MÄRZ' THEN 3 WHEN 'APRIL' THEN 4 ... WHEN 'DEZEMBER' THEN 12 ELSE 99 END
Zumindest bei MSSQL funktioniert das
  Mit Zitat antworten Zitat
Benutzerbild von erich.wanker
erich.wanker

Registriert seit: 31. Jan 2008
Ort: im schönen Salzburger Land
453 Beiträge
 
Delphi XE4 Professional
 
#4

AW: SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 9. Mär 2016, 16:55
Danke .. "ORDER BY CASE" funktioniert ..
Erich Wanker - for life:=1971 to lebensende do begin ..
O
/H\
/ \
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.275 Beiträge
 
Delphi 12 Athens
 
#5

AW: SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 9. Mär 2016, 19:22
Danke .. "ORDER BY CASE" funktioniert ..
...ja, ist aber ein Workaround für falsches DB Design. Mach es doch lieber richtig wie vorhin vorgeschlagen.
  Mit Zitat antworten Zitat
.Phil

Registriert seit: 19. Sep 2012
5 Beiträge
 
Turbo Delphi für Win32
 
#6

AW: SQL: Reihenfolge von Strings eines Feldes sortieren?

  Alt 10. Mär 2016, 10:39
Auch wenn die Lösung ja von mir kam, gutes Design ist es wirklich nicht. Aber oft genug hat man eben keinen Einfluss auf das DB-Design und muss einfach das Beste draus machen, bzw. halt irgendwas damit es funktioniert...
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:06 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz