Delphi-PRAXiS
Seite 3 von 4     123 4      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   SELECT-Statement in Delphi falsch, aber in Konsole richtig (https://www.delphipraxis.net/164226-select-statement-delphi-falsch-aber-konsole-richtig.html)

Maya 3. Nov 2011 12:53

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Zitat:

Zitat von Patito (Beitrag 1134284)
Um auszuschließen dass Du hier nicht an irgendein dummes 255-Zeichen-Limit stößt würde
ich mal statt das ganze SQL-Statement in einer einzelnen Zeile zu übergeben
das Statement in mehrere SQL.Add() hintereinander aufteilen.

Dann wird auch die Fehlermeldung mit Fehler in Zeile xy etwas aussagekräftiger...


Das mit den mehreren SQL.Add() hab ich schon probiert und kam weiterhin, dass das Problem in Zeile 1 liegt.

Zitat:

Zitat von DeddyH (Beitrag 1134283)
Benutz doch einmal Aliase und sag uns konkret, welche Tabellen Du unter welchen Bedingungen zusammenjoinen möchtest. Ich selber habe bei den ganzen Klammern und Subselects etwas den Überblick verloren.

Also bei den Mitarbeitern wird durch die Org-Id angegeben, in welcher Abteilung sie arbeiten. Manche der Abteilungen haben aber noch eine übergeordnete Abteilung, die durch das "higher_ranking" in der Orga-Tabelle angebenen ist. Das entsprechende Higher-Ranking entspricht dann einer Orga-ID der Orga-Tabelle.
In der Ausgabe soll dann halt der Mitarbeiter dastehen und seine Abteilung ggf. die übergeordnete Abteilung.

Noch mal kurz: Orga-Tabelle: alle Abteilungen mit Org-ID, Bezeichnung und higher-ranking welche einer Org-Id entspricht
Mitarbeiter-Tabelle: alle Mitarbeiter mit Abteilung (Org-ID)

Nachtrag
Ich bin jetzt unterwegs, schaue aber per Handy hier immer mal 'rein. Kann aber halt nix konkret dann ausprobieren, erst morgen früh wieder.

DeddyH 3. Nov 2011 12:57

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Wenn ich das richtig überblickt habe, kommst Du auch ganz ohne Subselects aus. Das kann ich aber erst später auseinanderklamüsern, da ich hier noch auf Arbeit bin.

[edit] Du willst also alle Mitarbeiter, Ihre Abteilung sowie die ggf. übergeordnete Abteilung ermitteln, stimmt das so?
Was kommt denn hierbei heraus?
SQL-Code:
SELECT
  M.[mitarbeiter_id],
  M.[nachname],
  M.[vorname],
  M.[org_id],
  O.[bezeichnung],
  O2.[bezeichnung]
FROM
  [pb_mitarbeiter] M
JOIN
  [pb_orga] O ON O.[org_id] = M.[org_id]
LEFT JOIN
  [pb_orga] O2 ON O2.[org_id] = O.[higher_ranking]
[/edit]

p80286 3. Nov 2011 14:36

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
dieses seltsame Higher_Ranking/Org_ID - Pärchen stört mich noch,
ansonsten finde ich an deddyhs Lösung nichts auszusetzen.

Gruß
K-h

DeddyH 3. Nov 2011 14:37

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Was stört Dich daran? Das ist ein simpler Self-Join.

mkinzler 3. Nov 2011 14:41

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Da es sich um 2 verschiedene Instanzen der selben Tabelle handelt, ist dies auch unumgänglich. Ist ausserdem nicht besonderst unüblich.

p80286 3. Nov 2011 15:05

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Tschuldigung falsch ausgedrückt,
mit higher_ranking wird, wenn ich das richtig verstanden habe, Org_id "ersetzt".
Aber nicht in allen Fällen(?) und solche Datenbasteleien erfüllen mich immer mit großem Mißtrauen.

Gruß
K-H

Bummi 3. Nov 2011 15:08

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
@p80286

ich verstehe das als Baumstruktur wo higher_ranking auf einen Vater verweisen kann, aber nicht muß

p80286 3. Nov 2011 15:20

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
wenn aber Higher_Ranking NULL ist?
Zitat:

Also bei den Mitarbeitern wird durch die Org-Id angegeben, in welcher Abteilung sie arbeiten. Manche der Abteilungen haben aber noch eine übergeordnete Abteilung, die durch das "higher_ranking" in der Orga-Tabelle angebenen ist. Das entsprechende Higher-Ranking entspricht dann einer Orga-ID der Orga-Tabelle.
Das wäre aber ein sehr kleiner Baum, das sehe ich eher als "Übersetzung".
Ist aber alles Spekulatius ohne zu wissen was wirklich in den Daten steht.

Gruß
K-H

mquadrat 3. Nov 2011 15:26

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Flache Hierarchien liegen doch im Trend :D

Bummi 3. Nov 2011 15:42

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
ja, ich könnte mir vorstellen daß es auf sowas rausläuft ...
Code:
Create FUNCTION [dbo].[FT_AbteilungsHirarchi](@org_id int)
RETURNS varchar(8000)
as
begin
Declare @Pfad varchar(8000)
Select @Pfad=Bezeichnung from dbo.pb_orga where org_id=@org_id
if Exists(Select * from dbo.pb_orga where org_id = (Select higher_ranking from pb_orga where org_id=@org_id))
   Select @Pfad=@Pfad + '/' + dbo.[FT_AbteilungsHirarchi]((Select higher_ranking from pb_orga where org_id=@org_id))
Return @Pfad
end


Select dbo.pb_mitarbeiter.*,[dbo].[FT_AbteilungsHirarchi](pb_mitarbeiter.org_id) as [Abteilung(en)]
from pb_mitarbeiter


Alle Zeitangaben in WEZ +1. Es ist jetzt 23:41 Uhr.
Seite 3 von 4     123 4      

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