다음은 내 테이블의 발췌입니다.
gid | datepose | pvc
---------+----------------+------------
1 | 1961 | 01
2 | 1949 |
3 | 1990 | 02
1 | 1981 |
1 | | 03
1 | |
다음을 사용하여 PVC 열을 채우고 싶습니다 SELECT CASE
.
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 ;
결과는 소스 테이블과 동일한 내용이며 아무 일도 일어나지 않았으며 pg_log 파일에 오류 메시지가 표시되지 않습니다. 구문 오류이거나 WHEN 절에서 여러 조건을 사용하는 데 문제가 있습니까?
도움과 조언에 감사드립니다!
NULL
, 예를 들면