Seite 1 von 1

gelöst: SQL-Abfrage: Mit decode Werte anders ausgeben ...

Verfasst: Mi 15. Feb 2017, 20:03
von geklgekl
Hallo Liste.

Ich habe die Jameica/JVerein-DB in Base eingebunden.
Darin gibt es eine Abfrage auf die Mitgliedertabelle(n).
Soweit alles klar.

Mein Problem:
Ich habe eine Spalte mit Kategorien: Darin gibt es vier verschiedenen Werte (derzeit):
26 ---> bedeutet XPRG
27 ---> bedeutet 1PRG
28 ---> bedeutet 1PLK
29 ---> bedeutet ÜPLK

Ich möchte in der Abfrage als Ergebnis aber nicht die Werte 26 bis 29 haben, sondern "übersetzte, so wie wir intern diese Zahlen betrachten. Also z.b. 1PRG für den Wert 27.

Ich weiss aber nicht wie ich das in den Select integrieren kann. Das müsste doch mit dem SQL-Befehl decode gehen ... aber leider habe ich das Knowhow nicht dazu ...

Hier mal der Select:

------------------------------
SELECT
"MITGLIED"."ID" "ID", "MITGLIED"."EXTERNEMITGLIEDSNUMMER" "EXTERNEMITGLIEDSNUMMER", "MITGLIED"."ADRESSTYP" "ADRESSTYP", "MITGLIED"."PERSONENART" "PERSONENART", "MITGLIED"."ANREDE" "ANREDE", "MITGLIED"."TITEL" "TITEL",
"MITGLIED"."NAME" "NAME", "MITGLIED"."VORNAME" "VORNAME", "MITGLIED"."ADRESSIERUNGSZUSATZ" "ADRESSIERUNGSZUSATZ", "MITGLIED"."STRASSE" "STRASSE", "MITGLIED"."PLZ" "PLZ", "MITGLIED"."ORT" "ORT", "MITGLIED"."STAAT" "STAAT",
"MITGLIED"."ZAHLUNGSWEG" "ZAHLUNGSWEG", "MITGLIED"."ZAHLUNGSRHYTMUS" "ZAHLUNGSRHYTMUS", "MITGLIED"."BIC" "BLZ", "MITGLIED"."IBAN" "KONTO", "MITGLIED"."KTOINAME" "KONTOINHABER", "MITGLIED"."GEBURTSDATUM" "GEBURTSDATUM",
"MITGLIED"."GESCHLECHT" "GESCHLECHT", "MITGLIED"."TELEFONPRIVAT" "TELEFONPRIVAT", "MITGLIED"."TELEFONDIENSTLICH" "TELEFONDIENSTLICH", "MITGLIED"."HANDY" "HANDY", "MITGLIED"."EMAIL" "EMAIL", "MITGLIED"."EINTRITT" "EINTRITT",
"MITGLIED"."BEITRAGSGRUPPE" "BEITRAGSGRUPPE", "MITGLIED"."INDIVIDUELLERBEITRAG" "INDIVIDUELLERBEITRAG", "MITGLIED"."ZAHLERID" "ZAHLERID", "MITGLIED"."AUSTRITT" "AUSTRITT", "MITGLIED"."KUENDIGUNG" "KUENDIGUNG",
"MITGLIED"."STERBETAG" "STERBETAG", "MITGLIED"."VERMERK1" "VERMERK1", "MITGLIED"."VERMERK2" "VERMERK2", "MITGLIED"."EINGABEDATUM" "EINGABEDATUM", "MITGLIED"."LETZTEAENDERUNG" "LETZTEAENDERUNG", "ZUSATZFELDER"."ID" "Z_ID",
"ZUSATZFELDER"."MITGLIED" "Z_MITGLIED", "ZUSATZFELDER"."FELDDEFINITION" "WART", "ZUSATZFELDER"."FELD" "FELD", "ZUSATZFELDER"."FELDDATUM" "FELDDATUM", "ZUSATZFELDER"."FELDGANZZAHL" "FELDGANZZAHL",
"ZUSATZFELDER"."FELDGLEITKOMMAZAHL" "FELDGLEITKOMMAZAHL", "ZUSATZFELDER"."FELDWAEHRUNG" "FELDWAEHRUNG", "ZUSATZFELDER"."FELDJANEIN" "FELDJANEIN"
FROM
"JVEREIN"."PUBLIC"."MITGLIED" AS "MITGLIED",
"JVEREIN"."PUBLIC"."ZUSATZFELDER" AS "ZUSATZFELDER"
WHERE
"MITGLIED"."ID" = "ZUSATZFELDER"."MITGLIED" AND "ZUSATZFELDER"."FELDDEFINITION" IN ( '26', '27', '28', '29' ) AND "FELDJANEIN" = '1'
AND "MITGLIED"."ADRESSTYP" = '5' ORDER BY "STAAT" ASC, "MITGLIED"."NAME" ASC
------------------------------

Es geht um das hier: im select-Teil
"ZUSATZFELDER"."FELDDEFINITION" "WART",
Im Where-Teil
"ZUSATZFELDER"."FELDDEFINITION" IN ( '26', '27', '28', '29' )

Hat mir jemand bitte den entscheidenden Tip?
Danke
Gruss vom Bodensee

Gerhard

Re: SQL-Abfrage: Mit decode Werte anders ausgeben ...

Verfasst: Do 16. Feb 2017, 11:52
von gogo
am einfachsten vermutlich mit einer 2. Tabelle in dem die Werte den entsprechenden Strings zugeordnet sind:
Tabelle Kategorien:
ID_Kategorie;Bezeichnung
26;'XPRG'
27;'1PRG'
28;'1PLK'
29;'ÜPLK'

und dann:
select ... , "KATEGORIEN"."BEZEICHNUNG", ...
FROM
"JVEREIN"."PUBLIC"."MITGLIED" AS "MITGLIED",
"JVEREIN"."PUBLIC"."ZUSATZFELDER" AS "ZUSATZFELDER"
"JVEREIN"."PUBLIC"."KATEGORIEN" AS "KATEGORIEN"
WHERE
"MITGLIED"."ID" = "ZUSATZFELDER"."MITGLIED" AND "ZUSATZFELDER"."FELDDEFINITION" IN ( '26', '27', '28', '29' ) AND "FELDJANEIN" = '1'
AND "MITGLIED"."ADRESSTYP" = '5' AND "KATEGORIEN"."ID_KATEGORIE" = "ZUSATZFELDER"."FELDDEFINITION"

Re: SQL-Abfrage: Mit decode Werte anders ausgeben ...

Verfasst: Do 16. Feb 2017, 17:38
von RobertG
Hallo Gerhard,

die Funktion DECODE kennt nur Firebird, nicht die HSQLDB. Außerdem wäre sie hier nicht zielführend. Sinnvoller wäre die Funktion

Code: Alles auswählen

CASE 
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '26' THEN 'XPRG'
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '27'  THEN '1PRG'
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '28'  THEN '1PLK'
ELSE 'ÜPLK'
END
Allerdings würde ich auch, wie gogo, eine zweite Tabelle vorziehen. Das ist einfach übersichtlicher und Du musst nicht im Code hart herumprogrammieren sondern weißt hinterher, woher die Werte kommen.

Gruß

Robert

gelöst: SQL-Abfrage: Mit decode Werte anders ausgeben ...

Verfasst: Do 16. Feb 2017, 18:48
von geklgekl
Hallo Liste.
Super, vielen Dank.
Habe es direkt im SQL hin bekommen.
Merci Gerhard

SELECT
"MITGLIED"."ID" "ID", "MITGLIED"."EXTERNEMITGLIEDSNUMMER" "EXTERNEMITGLIEDSNUMMER", "MITGLIED"."ADRESSTYP" "ADRESSTYP", "MITGLIED"."PERSONENART" "PERSONENART", "MITGLIED"."ANREDE" "ANREDE", "MITGLIED"."TITEL" "TITEL",
"MITGLIED"."NAME" "NAME", "MITGLIED"."VORNAME" "VORNAME", "MITGLIED"."ADRESSIERUNGSZUSATZ" "ADRESSIERUNGSZUSATZ", "MITGLIED"."STRASSE" "STRASSE", "MITGLIED"."PLZ" "PLZ", "MITGLIED"."ORT" "ORT", "MITGLIED"."STAAT" "STAAT",
"MITGLIED"."ZAHLUNGSWEG" "ZAHLUNGSWEG", "MITGLIED"."ZAHLUNGSRHYTMUS" "ZAHLUNGSRHYTMUS", "MITGLIED"."BIC" "BLZ", "MITGLIED"."IBAN" "KONTO", "MITGLIED"."KTOINAME" "KONTOINHABER", "MITGLIED"."GEBURTSDATUM" "GEBURTSDATUM",
"MITGLIED"."GESCHLECHT" "GESCHLECHT", "MITGLIED"."TELEFONPRIVAT" "TELEFONPRIVAT", "MITGLIED"."TELEFONDIENSTLICH" "TELEFONDIENSTLICH", "MITGLIED"."HANDY" "HANDY", "MITGLIED"."EMAIL" "EMAIL", "MITGLIED"."EINTRITT" "EINTRITT",
"MITGLIED"."BEITRAGSGRUPPE" "BEITRAGSGRUPPE", "MITGLIED"."INDIVIDUELLERBEITRAG" "INDIVIDUELLERBEITRAG", "MITGLIED"."ZAHLERID" "ZAHLERID", "MITGLIED"."AUSTRITT" "AUSTRITT", "MITGLIED"."KUENDIGUNG" "KUENDIGUNG",
"MITGLIED"."STERBETAG" "STERBETAG", "MITGLIED"."VERMERK1" "VERMERK1", "MITGLIED"."VERMERK2" "VERMERK2", "MITGLIED"."EINGABEDATUM" "EINGABEDATUM", "MITGLIED"."LETZTEAENDERUNG" "LETZTEAENDERUNG", "ZUSATZFELDER"."ID" "Z_ID",
"ZUSATZFELDER"."MITGLIED" "Z_MITGLIED", "ZUSATZFELDER"."FELD" "FELD", "ZUSATZFELDER"."FELDDATUM" "FELDDATUM", "ZUSATZFELDER"."FELDGANZZAHL" "FELDGANZZAHL",
"ZUSATZFELDER"."FELDGLEITKOMMAZAHL" "FELDGLEITKOMMAZAHL", "ZUSATZFELDER"."FELDWAEHRUNG" "FELDWAEHRUNG", "ZUSATZFELDER"."FELDJANEIN" "FELDJANEIN",
CASE
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '26' THEN 'XPRG'
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '27' THEN '1PRG'
WHEN "ZUSATZFELDER"."FELDDEFINITION" = '28' THEN '1PLK'
ELSE 'ÜPLK'
END
AS "WART"
FROM
"JVEREIN"."PUBLIC"."MITGLIED" AS "MITGLIED",
"JVEREIN"."PUBLIC"."ZUSATZFELDER" AS "ZUSATZFELDER"
WHERE
"MITGLIED"."ID" = "ZUSATZFELDER"."MITGLIED" AND "ZUSATZFELDER"."FELDDEFINITION" IN ( '26', '27', '28', '29' ) AND "FELDJANEIN" = '1'
AND "MITGLIED"."ADRESSTYP" = '5' ORDER BY "STAAT" ASC, "MITGLIED"."NAME" ASC