SQL - bitte um erklärung

drfuture

Zeitreisender
Teammitglied
Registriert
14 Juli 2013
Beiträge
7.710
Ort
in der Zukunft
Servus zusammen,
ich habe einen SQL-Query der sich mir nicht so ganz erschließt... das heißt ich kann ihn für mich nicht Sinnvoll Gruppieren und damit dann auch Anpassen.

[src=mysql]SELECT @IF('@SUB(FORM_NAME)' = 'Form1', 'status from (SELECT ''Neu'' as ''status'' ,1 as orderby WHERE ''@SUB(Status)'' = ''Neu'' union SELECT ''Registriert'',2 WHERE ''@SUB(Status)'' <> ''In Bearbeitung'' AND ''@SUB(Status)'' <> ''Gelöst'' AND ''@SUB(Status)'' <> ''Ausgesetzt'' union select ''In Bearbeitung'',3 union select ''Ausgesetzt'',5 union select ''Gelöst'',6) status order by orderby ', 'status from (SELECT ''Neu'' as ''status'' ,1 as orderby union select ''Registriert'',2 union select ''In Bearbeitung'',3 union select ''Ausgesetzt'',5 union select ''Gelöst'',6) status order by orderby')[/src]

@SUB() wird bei der Verarbeitung durch einen Feldnamen ersetzt - Normal sollte das nur SQL sein - kann aber leider auch sein das ein Paar Befehle z.B. das@IF.. auch noch Steuerungsfunktionen aus der Anwendung sind die den SQL-Befehl ausführt. Die Dokumentation ist hier etwas "ungenügend"

Ich müsste die Abfrage nun um einen zusätzlichen Wert ergänzen bzw. veringern.
Das Ergebnis kenne ich - es wird in Abhängigkeit des Inhaltes von "Status" eine Liste an Werten ausgeben, wobei die Werte nicht aus einer Tabelle kommen sondern fix in der SQL-Abfrage vorgegeben sind.

--- [2013-08-26 16:12 CEST] Automatisch zusammengeführter Beitrag ---

[src=mysql]SELECT @IF('@SUB(FORM_NAME)' = 'Form1', 'status from (SELECT ''vorgeschlagen'' as ''status'' ,1 as orderby WHERE ''@SUB(status)'' = ''vorgeschlagen'' union SELECT ''in inhaltlicher Prüfung'',2 WHERE ''@SUB(status)'' <> ''in redaktioneller Prüfung'' AND ''@SUB(status)'' <> ''Angenommen'' AND ''@SUB(status)'' <> ''Abgelehnt'' AND ''@SUB(status)'' <> ''abgelaufen/erledigt'' union select ''in redaktioneller Prüfung'',3 WHERE ''@SUB(status)'' <> ''vorgeschlagen'' AND ''@SUB(status)'' <> ''Angenommen'' AND ''@SUB(status)'' <> ''Abgelehnt'' AND ''@SUB(status)'' <> ''abgelaufen/erledigt'' union select ''angenommen'',4 WHERE ''@SUB(status)'' <> ''vorgeschlagen'' AND ''@SUB(status)'' <> ''in inhalticher Prüfung'' AND ''@SUB(status)'' <> ''Abgelehnt'' AND ''@SUB(status)'' <> ''abgelaufen/erledigt'' union select ''abgelehnt'',5 WHERE ''@SUB(status)'' <> ''vorgeschlagen'' AND ''@SUB(status)'' <> ''in inhalticher Prüfung'' AND ''@SUB(status)'' <> ''Abgelehnt'' AND ''@SUB(status)'' <> ''abgelaufen/erledigt'' union select ''abgelaufen/erledigt'',6 WHERE ''@SUB(status)'' <> ''vorgeschlagen'' AND ''@SUB(status)'' <> ''in inhalticher Prüfung'' AND ''@SUB(status)'' <> ''in redaktioneller Prüfung'') status',)[/src]

So funktioniert es wie gewünscht... k.a warum - aber es passt nun ;)
 
Zuletzt bearbeitet:
Das sieht aus, wie Durchfall :D

So müsste die Einrückung schon mal stimmen:

[src=mysql]SELECT
@IF('@SUB(FORM_NAME)' = 'Form1', 'status
from
(SELECT ''Neu'' as ''status'' , 1 as orderby
WHERE ''@SUB(Status)'' = ''Neu''
union
SELECT ''Registriert'', 2
WHERE ''@SUB(Status)'' <> ''In Bearbeitung'' AND
''@SUB(Status)'' <> ''Gelöst'' AND
''@SUB(Status)'' <> ''Ausgesetzt''
union
select ''In Bearbeitung'',3
union
select ''Ausgesetzt'',5
union
select ''Gelöst'',6
) status
order by orderby ',
'status
from
(SELECT ''Neu'' as ''status'' ,1 as orderby
union
select ''Registriert'',2
union
select ''In Bearbeitung'',3
union
select ''Ausgesetzt'',5
union
select ''Gelöst'',6) status
order by orderby')[/src]

Wenn '@SUB(FORM_NAME)' = 'Form1' wahr ist, dann

[src=mysql]'status
from
(SELECT ''Neu'' as ''status'' , 1 as orderby
WHERE ''@SUB(Status)'' = ''Neu''
union
SELECT ''Registriert'', 2
WHERE ''@SUB(Status)'' <> ''In Bearbeitung'' AND
''@SUB(Status)'' <> ''Gelöst'' AND
''@SUB(Status)'' <> ''Ausgesetzt''
union
select ''In Bearbeitung'',3
union
select ''Ausgesetzt'',5
union
select ''Gelöst'',6) status
order by orderby '[/src]
Also wenn og Ausdruck wahr ist, wird SELECT status von dem Subquery (welches aus den ganzen unions besteht) ausgeführt.
Falls og. Ausdruck falsch ist, dann wird eben SELECT status von dem zweiten Subquery ausgeführt:

[src=mysql]'status
from
(SELECT ''Neu'' as ''status'' ,1 as orderby
union
select ''Registriert'',2
union
select ''In Bearbeitung'',3
union
select ''Ausgesetzt'',5
union
select ''Gelöst'',6) status
order by orderby')[/src]

Jeweils die geklammerten (SELECT ...) Subquerys werden dann wie eine neue Tabelle (namens status) behandelt und nach orderby geordnet.


Was genau war noch mal die Frage? :D
 
  • Thread Starter Thread Starter
  • #3
Hm glaube ich hab beim ersten durchsehen das , und somit den "wenn falsch" Teil übersehen in dem "Durchfall" ... Ich hab dann einfach von 0 Angefangen und habs so probiert wie ich gehofft habe das es funktioniert - >> Hat ja dann auch geklappt,
aber Danke für die Nachträgliche Erklärung so ergibt das wirklich mehr Sinn ... Wer genauer hin schaut sieht halt oft doch mehr :D
 
Gibt eine Programmiersprache, die von Einrückungen lebt.
Das ist zwar sehr übertrieben, aber dafür ist der Code dann auch übersichtlicher.

In der modifizierten Version von dir, sollte allerdings nur dann etwas passieren, wenn die Bedingung erfüllt ist, in dem Fall, dass die Bedingung falsch ist, sollte gar nichts passieren.
Bist du dir sicher, dass das so gewünscht ist?
 
  • Thread Starter Thread Starter
  • #5
Jep ist so gewünscht, bzw. ist vollkommen außreichend - mir ist eher schleierhaft warum es den 2. Fall in der ersten Version überhaupt gibt...
 
Zurück
Oben