AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SELECT-Statement in Delphi falsch, aber in Konsole richtig
Thema durchsuchen
Ansicht
Themen-Optionen

SELECT-Statement in Delphi falsch, aber in Konsole richtig

Ein Thema von Maya · begonnen am 3. Nov 2011 · letzter Beitrag vom 4. Nov 2011
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Maya
Maya

Registriert seit: 15. Jun 2011
Ort: Potsdam-Mittelmark
107 Beiträge
 
Delphi 2010 Enterprise
 
#1

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

  Alt 3. Nov 2011, 12:23
Code:
SELECT [pb_mitarbeiter].[mitarbeiter_id],                      
       [pb_mitarbeiter].[nachname],                          
       [pb_mitarbeiter].[vorname],                            
       [pb_mitarbeiter].[org_id],                            
       [pb_orga].[bezeichnung],                        
       Tabelle2.[bezeichnung]                                
FROM                                                          
     (SELECT Tabelle.[org_id],                            
             Tabelle.[higher_ranking],                    
             [pb_orga].[bezeichnung]                
      FROM                                                
            (SELECT [pb_orga].[org_id],          
                    [pb_orga].[bezeichnung],      
                    [pb_orga].[higher_ranking]    
             FROM [pb_orga]) Tabelle, [pb_orga]          
      WHERE [pb_orga].[org_id]=Tabelle.[higher_ranking])          
   Tabelle2 RIGHT JOIN ([pb_mitarbeiter]                
            RIGHT JOIN [pb_orga]                
                      ON [pb_mitarbeiter].[org_id]=[pb_orga].[org_id])    
                      ON Tabelle2.[org_id]=[pb_mitarbeiter].[org_id]    
WHERE [pb_mitarbeiter].[mitarbeiter_id] IS NOT NULL
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#2

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

  Alt 3. Nov 2011, 12:28
Das sieht in der Tat nahezu identisch aus.
Das einzige was mir auffällt, Deine Bedingung (Delphi Parameter) fehlt hier.
An der Zeilennummer würde ich mich nicht unbedingt hochziehen.
Gruß, Jo
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.660 Beiträge
 
Delphi 12 Athens
 
#3

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

  Alt 3. Nov 2011, 12:31
Die JOIN-Bedingungen sehen mir etwas merkwürdig aus.
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
Benutzerbild von Maya
Maya

Registriert seit: 15. Jun 2011
Ort: Potsdam-Mittelmark
107 Beiträge
 
Delphi 2010 Enterprise
 
#4

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

  Alt 3. Nov 2011, 12:34
Das sieht in der Tat nahezu identisch aus.
Das einzige was mir auffällt, Deine Bedingung (Delphi Parameter) fehlt hier.
An der Zeilennummer würde ich mich nicht unbedingt hochziehen.
Das ist korrekt. Das kommt daher, da ich im Programm die Möglichkeit anbiete, dass die Mitarbeiter noch mal nach Bedingungen gefiltert werden können. Damit ich nicht jedes Mal die Anweisung schreiben muss, hab ich deswegen eine allgemeingültige Procedure gebastelt, wo ich ggf. einfach die weiteren WHERE-Bedingungen dranhänge.

Die JOIN-Bedingungen sehen mir etwas merkwürdig aus.
Dann sag mir aber auch bitte, was da konkret merkwürdig ist. Bin nicht so der Crack in Joins, aber ich hab mich an das Muster hier gehalten: http://aktuell.de.selfhtml.org/artik...rfachjoin1.htm
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.660 Beiträge
 
Delphi 12 Athens
 
#5

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

  Alt 3. Nov 2011, 12:40
Da steht
Zitat:
SQL-Code:
RIGHT JOIN ...
RIGHT JOIN ...
ON ...
ON ...
(OK, geklammert, das macht es aber nicht lesbarer) anstatt
SQL-Code:
RIGHT JOIN ...
ON ...
RIGHT JOIN ...
ON ...
Das meinte ich mit merkwürdig. An Deiner Stelle würde ich mir das Statement zunächst speichern und dann im Kleinen neu aufbauen. Klappt das hier?
SQL-Code:
SELECT [pb_mitarbeiter].[mitarbeiter_id]
FROM [pb_mitarbeiter]
WHERE [pb_mitarbeiter].[mitarbeiter_id] IS NOT NULL
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
Benutzerbild von Maya
Maya

Registriert seit: 15. Jun 2011
Ort: Potsdam-Mittelmark
107 Beiträge
 
Delphi 2010 Enterprise
 
#6

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

  Alt 3. Nov 2011, 12:44
Da steht
Zitat:
SQL-Code:
RIGHT JOIN ...
RIGHT JOIN ...
ON ...
ON ...
(OK, geklammert, das macht es aber nicht lesbarer) anstatt
SQL-Code:
RIGHT JOIN ...
ON ...
RIGHT JOIN ...
ON ...
Das meinte ich mit merkwürdig.
Ich meinte konkret eher den komplexeren Fall. Den empfand ich als passender für mein Problem.

An Deiner Stelle würde ich mir das Statement zunächst speichern und dann im Kleinen neu aufbauen. Klappt das hier?
SQL-Code:
SELECT [pb_mitarbeiter].[mitarbeiter_id]
FROM [pb_mitarbeiter]
WHERE [pb_mitarbeiter].[mitarbeiter_id] IS NOT NULL
Joar, da kommen halt alle Mitarbeiter bei mir 'raus. Es hat ja jeder 'ne ID, da's der PK ist.
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.660 Beiträge
 
Delphi 12 Athens
 
#7

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

  Alt 3. Nov 2011, 12:48
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.
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
Patito

Registriert seit: 8. Sep 2006
108 Beiträge
 
#8

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

  Alt 3. Nov 2011, 12:49
Aus den Postings bisher ist mir noch nicht ganz klar was für eine Datenbankkomponente hier im Einsatz ist.

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...
  Mit Zitat antworten Zitat
Benutzerbild von Maya
Maya

Registriert seit: 15. Jun 2011
Ort: Potsdam-Mittelmark
107 Beiträge
 
Delphi 2010 Enterprise
 
#9

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

  Alt 3. Nov 2011, 12:53
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.

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.
Status:
- FIAE
- Rechteinhaberin, ein Rüsselmops sein zu wollen

Geändert von Maya ( 3. Nov 2011 um 12:54 Uhr) Grund: Nachtrag
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.660 Beiträge
 
Delphi 12 Athens
 
#10

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

  Alt 3. Nov 2011, 12:57
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]
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

Geändert von DeddyH ( 3. Nov 2011 um 13:26 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 10:10 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz