Delphi-PRAXiS
Seite 2 von 4     12 34      

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:18

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

Zitat von Sherlock (Beitrag 1134256)
Nur nebenbei: SQL ist eine Stringliste. Mach doch für jede Zeile ein eigenes Add. Dann sind das wirklich auch getrennte Zeilen und man muss nicht auf Leerzeichen oder Carriagereturns Rücksicht nehmen.

Sherlock

Nope, immer noch Zeile 1.

Zitat:

Zitat von jobo (Beitrag 1134255)
Deine gesamte From Clause besteht nur aus einer Tabelle/Select/Alias!
Durch die Klammerung werden sämtliche Subselects innerhalb nicht mehr als eigenständige Tabellen erkannt. Da kannst Du alle Tabellen der Datenbank eintragen, ein Select darauf wird nicht funktionieren.
(Und kann auch in der Console nicht funktionieren)

Kannst mir gerne glauben. Wenn ich direkt in Microsoft SQL den Code so eingeben, spuckt er mir die Tabelle so aus, wie ich sie haben möchte.

Ich weiß nicht, was ich weiterhin dazu sagen soll, außer das ich ratlos bin.

jobo 3. Nov 2011 12:19

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Kopier doch mal die Consolen SQL Version hier rein.

Maya 3. Nov 2011 12:23

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
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

jobo 3. Nov 2011 12:28

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
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.

DeddyH 3. Nov 2011 12:31

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
Die JOIN-Bedingungen sehen mir etwas merkwürdig aus.

Maya 3. Nov 2011 12:34

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

Zitat von jobo (Beitrag 1134271)
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.

Zitat:

Zitat von DeddyH (Beitrag 1134272)
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

DeddyH 3. Nov 2011 12:40

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
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

Maya 3. Nov 2011 12:44

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

Zitat von DeddyH (Beitrag 1134277)
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.

Zitat:

Zitat von DeddyH (Beitrag 1134277)
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.

DeddyH 3. Nov 2011 12:48

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
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.

Patito 3. Nov 2011 12:49

AW: SELECT-Statement in Delphi falsch, aber in Konsole richtig
 
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...


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:59 Uhr.
Seite 2 von 4     12 34      

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