Hier ist ein Auszug aus meinem Tisch:
gid | datepose | pvc
---------+----------------+------------
1 | 1961 | 01
2 | 1949 |
3 | 1990 | 02
1 | 1981 |
1 | | 03
1 | |
Ich möchte die PVC-Spalte mit einem SELECT CASE
wie folgt:
SELECT
gid,
CASE
WHEN (pvc IS NULL OR pvc = '') AND datpose < 1980) THEN '01'
WHEN (pvc IS NULL OR pvc = '') AND datpose >= 1980) THEN '02'
WHEN (pvc IS NULL OR pvc = '') AND (datpose IS NULL OR datpose = 0) THEN '03'
END AS pvc
FROM my_table ;
Das Ergebnis ist der gleiche Inhalt wie in der Quelltabelle, es ist nichts passiert und in den pg_log-Dateien wird keine Fehlermeldung angezeigt. Möglicherweise handelt es sich um einen Syntaxfehler oder um ein Problem bei der Verwendung mehrerer Bedingungen in WHEN-Klauseln.
Danke für Hilfe und Rat!
Diese Art von Code sollte vielleicht für Sie funktionieren
SELECT
*,
CASE
WHEN (pvc IS NULL OR pvc = '') AND (datepose < 1980) THEN '01'
WHEN (pvc IS NULL OR pvc = '') AND (datepose >= 1980) THEN '02'
WHEN (pvc IS NULL OR pvc = '') AND (datepose IS NULL OR datepose = 0) THEN '03'
ELSE '00'
END AS modifiedpvc
FROM my_table;
gid | datepose | pvc | modifiedpvc
-----+----------+-----+-------------
1 | 1961 | 01 | 00
2 | 1949 | | 01
3 | 1990 | 02 | 00
1 | 1981 | | 02
1 | | 03 | 00
1 | | | 03
(6 rows)