AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken [SQL] Tabelle nach Kategorien sortieren
Thema durchsuchen
Ansicht
Themen-Optionen

[SQL] Tabelle nach Kategorien sortieren

Ein Thema von new32 · begonnen am 23. Jul 2010 · letzter Beitrag vom 24. Jul 2010
Antwort Antwort
new32

Registriert seit: 10. Mai 2005
160 Beiträge
 
Delphi 7 Enterprise
 
#1

[SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 18:56
Datenbank: Paradox • Version: 7 • Zugriff über: SQL
Hallo,

ich habe eine Tabelle, in der eine Spalte eine Kategorie enthält.

Nun kann es vorkommen, dass Zeilen, die zu einer Kategorie gehören nicht direkt untereinander stehen, also durch Zeilen, die zu einer anderen Kategorie gehören, getrennt werden:

Wert1 Kategorie2
Wert2 Kategorie1
Wert3 Kategorie2


Nun möchte ich die Zeilen in der Ausabe nach Kategorien sortieren, ohne aber diese alphabetisch zu sortieren.

Die Ausgabe sollte also wie folgt aussehen:

Wert1 Kategorie2
Wert3 Kategorie2
Wert2 Kategorie1


und nicht:

Wert2 Kategorie1
Wert1 Kategorie2
Wert3 Kategorie2

Wie ist es möglich dies mit SQL zu erledigen?

Schon einmal Danke im Voraus!

mgf
~?&/%§$§%\&?~
8)
  Mit Zitat antworten Zitat
blackfin
(Gast)

n/a Beiträge
 
#2

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 19:00
ORDER BY Kategorie DESC, Wert ASC

...?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 19:01
Und wie soll dann sortiert werden?
Markus Kinzler
  Mit Zitat antworten Zitat
new32

Registriert seit: 10. Mai 2005
160 Beiträge
 
Delphi 7 Enterprise
 
#4

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 19:06
Die Kategorie, die als 1. auftaucht, soll auch weiterhin die 1. bleiben; die zweite Kategorie auch weiter die 2.
~?&/%§$§%\&?~
8)
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#5

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 19:19
Die Kategorie, die als 1. auftaucht, soll auch weiterhin die 1. bleiben; die zweite Kategorie auch weiter die 2.
IMHO sollte die Position eines Datensatzes in einer Tabelle keine Rolle spielen. Wenn doch ist da was nicht ganz sauber.

Falls du unbedingt eine Reihenfolge ermöglichen möchtest, die nicht alphabetisch sortiert ist würde ich vorschlagen die Kategorien in eine eigene Tabelle auszulagern. Dann hast du die Kategorie-ID anhand der du sortieren kannst.
  Mit Zitat antworten Zitat
new32

Registriert seit: 10. Mai 2005
160 Beiträge
 
Delphi 7 Enterprise
 
#6

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 19:42
danke für die Antworten!

IMHO sollte die Position eines Datensatzes in einer Tabelle keine Rolle spielen. Wenn doch ist da was nicht ganz sauber.
spielt sie aber leider.

Zitat:
Falls du unbedingt eine Reihenfolge ermöglichen möchtest, die nicht alphabetisch sortiert ist würde ich vorschlagen die Kategorien in eine eigene Tabelle auszulagern. Dann hast du die Kategorie-ID anhand der du sortieren kannst.
Wäre möglich, aber die Änderungen recht aufwändig. Eine Lösung auf Tabellenbasis ist einfacher, wenn auch unelegant.
~?&/%§$§%\&?~
8)
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#7

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 23. Jul 2010, 20:56
Haben die Dinger vielleicht ein int-Feld als Primary Key auto increment? Nein, sonst hättest du wahrscheinlich nicht gefragt.

Dann fällt mir nur ein, erstmal alle Kategorien zu selektieren (evtl. geht ein group by category) und dann einzeln durchzugehen und für jede Kategorie seperat die Datensäze zu holen.
  Mit Zitat antworten Zitat
new32

Registriert seit: 10. Mai 2005
160 Beiträge
 
Delphi 7 Enterprise
 
#8

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 24. Jul 2010, 09:29
Dann fällt mir nur ein, erstmal alle Kategorien zu selektieren (evtl. geht ein group by category) und dann einzeln durchzugehen und für jede Kategorie seperat die Datensäze zu holen.
Schon das selektieren der Kategorien sortiert.

Code:
SELECT DISTINCT Kategorie
...
liefert ein sortiertes Ergebnis.
Eine separate Tabelle mit Kategorien habe ich leider nicht.

Danke trotzdem.
~?&/%§$§%\&?~
8)
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#9

AW: [SQL] Tabelle nach Kategorien sortieren

  Alt 24. Jul 2010, 12:34
Schon das selektieren der Kategorien sortiert.
Das ist völlig normal. Eine Datenbank ist immer mengenorientiert und innerhalb einer Menge gibt es keine Reihenfolge. Die Reihenfolge kann dann am Ende über ein ORDER BY erzwungen werden. Aber eine Reihenfolge der Datensätze gibt es nicht. Es sei denn in der Datenbank wird ein Timestamp abgelegt, der eben festhält wann der jeweilige Datensatz eingetragen wurde, dann kann das Ergebnis über diese Zeitangabe sortiert werden.
  Mit Zitat antworten Zitat
Antwort Antwort


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 12:51 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