AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Daten sortieren - SELECT ... ORDER BY ...
Thema durchsuchen
Ansicht
Themen-Optionen

Daten sortieren - SELECT ... ORDER BY ...

Ein Thema von spechto · begonnen am 17. Nov 2009 · letzter Beitrag vom 17. Nov 2009
Antwort Antwort
spechto

Registriert seit: 20. Jun 2009
28 Beiträge
 
Delphi 2007 Professional
 
#1

Daten sortieren - SELECT ... ORDER BY ...

  Alt 17. Nov 2009, 10:12
Datenbank: Firebird • Version: 2 • Zugriff über: FIBPlus
Hallo zusammen,

ich habe mal eine allgemeine Frage zum Thema SELECT und ORDER BY.

Als Beispiel nehme ich mal folgende Tabellen:

MITARBEITER
==================
ID integer (PK)
NAME varchar(20)
WOHNORT integer

WOHNORTE
==================
ID integer (PK)
WONAME varchar(20)

select ID, NAME, WOHNORT from MITARBEITER order by WOHNORT

funktioniert ja soweit, wenn ich allerdings nach WONAME
sortieren möchte, gibt es ein Problem mit:

select ID, NAME, WOHNORT from MITARBEITER order by WOHNORTE.WONAME

In einem DBGrid zeige ich den zum Wohnort gehörigen Namen mit einem
Lookup-Field des TDataSets an. Aber eine Sortierung auf SQL Ebene
scheint mir damit nicht möglich zu sein. Oder liege ich hier falsch?

Muss ich nun den select Befehl derart erweitern, dass neben der
ID (also WOHNORT) auch der WONAME per inner join mit aufgenommen
wird, oder gibt es einen eleganteren Weg?

Vielen Dank für Eure Hilfe

Viele Grüße
Martin
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#2

Re: Daten sortieren - SELECT ... ORDER BY ...

  Alt 17. Nov 2009, 10:21
Du kannst ja nicht nach Feldern sortieren, die gar nicht in der Ergebnismenge enthalten sind, deshalb wirst Du IMO nicht um einen JOIN herumkommen.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Daten sortieren - SELECT ... ORDER BY ...

  Alt 17. Nov 2009, 10:22
Du musst die Tabellen joinen:
SQL-Code:
select
  m.ID, m.NAME,
  w.woname as WOHNORT
from
    MITARBEITER m
    join WOHNORTE w on w.id = m.wohnort
order by
    W.WONAME;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von joachimd
joachimd

Registriert seit: 17. Feb 2005
Ort: Weitingen
672 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: Daten sortieren - SELECT ... ORDER BY ...

  Alt 17. Nov 2009, 12:03
Zitat von DeddyH:
Du kannst ja nicht nach Feldern sortieren, die gar nicht in der Ergebnismenge enthalten sind, deshalb wirst Du IMO nicht um einen JOIN herumkommen.
Doch, das geht: select vorname from buddies order by nachname Aber um den Join kommt man in diesem Fall nicht herum, da das Sortierfeld nicht Teil der Quelle ist.
Joachim Dürr
Joachim Dürr Softwareengineering
http://www.jd-engineering.de
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: Daten sortieren - SELECT ... ORDER BY ...

  Alt 17. Nov 2009, 12:05
Zitat von joachimd:
Aber um den Join kommt man in diesem Fall nicht herum, da das Sortierfeld nicht Teil der Quelle ist.
So hatte ich es eigentlich auch gemeint, aber Du kannst es besser ausdrücken
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  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 16:58 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