• Hallo liebe Userinnen und User,

    nach bereits längeren Planungen und Vorbereitungen sind wir nun von vBulletin auf Xenforo umgestiegen. Die Umstellung musste leider aufgrund der Serverprobleme der letzten Tage notgedrungen vorverlegt werden. Das neue Forum ist soweit voll funktionsfähig, allerdings sind noch nicht alle der gewohnten Funktionen vorhanden. Nach Möglichkeit werden wir sie in den nächsten Wochen nachrüsten. Dafür sollte es nun einige der Probleme lösen, die wir in den letzten Tagen, Wochen und Monaten hatten. Auch der Server ist nun potenter als bei unserem alten Hoster, wodurch wir nun langfristig den Tank mit Bytes vollgetankt haben.

    Anfangs mag die neue Boardsoftware etwas ungewohnt sein, aber man findet sich recht schnell ein. Wir wissen, dass ihr alle Gewohnheitstiere seid, aber gebt dem neuen Board eine Chance.
    Sollte etwas der neuen oder auch gewohnten Funktionen unklar sein, könnt ihr den "Wo issn da der Button zu"-Thread im Feedback nutzen. Bugs meldet ihr bitte im Bugtracker, es wird sicher welche geben die uns noch nicht aufgefallen sind. Ich werde das dann versuchen, halbwegs im Startbeitrag übersichtlich zu halten, was an Arbeit noch aussteht.

    Neu ist, dass die Boardsoftware deutlich besser für Mobiltelefone und diverse Endgeräte geeignet ist und nun auch im mobilen Style alle Funktionen verfügbar sind. Am Desktop findet ihr oben rechts sowohl den Umschalter zwischen hellem und dunklem Style. Am Handy ist der Hell-/Dunkelschalter am Ende der Seite. Damit sollte zukünftig jeder sein Board so konfigurieren können, wie es ihm am liebsten ist.


    Die restlichen Funktionen sollten eigentlich soweit wie gewohnt funktionieren. Einfach mal ein wenig damit spielen oder bei Unklarheiten im Thread nachfragen. Viel Spaß im ngb 2.0.

SQL - bitte um erklärung

drfuture

Zeitreisender
Teammitglied

Registriert
14 Juli 2013
Beiträge
8.754
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:

accC

gesperrt

Registriert
14 Juli 2013
Beiträge
5.250
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
 

drfuture

Zeitreisender
Teammitglied

Registriert
14 Juli 2013
Beiträge
8.754
Ort
in der Zukunft
  • 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
 

accC

gesperrt

Registriert
14 Juli 2013
Beiträge
5.250
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?
 

drfuture

Zeitreisender
Teammitglied

Registriert
14 Juli 2013
Beiträge
8.754
Ort
in der Zukunft
  • 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...
 
Oben