[IS NULL] NULL 처리하기

2024. 9. 17. 18:00SQL 고득점 Kit/IS NULL

https://school.programmers.co.kr/learn/courses/30/lessons/59410

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr


문제 설명
ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_IDANIMAL_TYPEDATETIMEINTAKE_CONDITIONNAMESEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

NAME TYPE NULLABLE
ANIMAL_ID VARCHAR(N) FALSE
ANIMAL_TYPE VARCHAR(N) FALSE
DATETIME DATETIME FALSE
INTAKE_CONDITION VARCHAR(N) FALSE
NAME VARCHAR(N) FALSE
SEX_UPON_INTAKE VARCHAR(N) FALSE

 

입양 게시판에 동물 정보를 게시하려 합니다. 동물의 생물 종, 이름, 성별 및 중성화 여부를 아이디 순으로 조회하는 SQL문을 작성해주세요. 이때 프로그래밍을 모르는 사람들은 NULL이라는 기호를 모르기 때문에, 이름이 없는 동물의 이름은 "No name"으로 표시해 주세요.


예시
예를 들어 ANIMAL_INS 테이블이 다음과 같다면

ANIMAL_ID ANIMAL_TYPE DATETIME INTAKE_CONDITION NAME SEX_UPON_INTAKE
A350276 Cat 2017-08-13 13:50:00 Normal Jewel Spayed Female
A350375 Cat 2017-03-06 15:01:00 Normal Meo Neutered Male
A368930 Dog 2014-06-08 13:20:00 Normal NULL Spayed Female

 

마지막 줄의 개는 이름이 없기 때문에, 이 개의 이름은 "No name"으로 표시합니다. 따라서 SQL문을 실행하면 다음과 같이 나와야 합니다.

ANIMAL_TYPE NAME SEX_UPON_INTAKE
Cat Jewel Spayed Female
Cat Meo Neutered Male
Dog No name Spayed Female


※ 컬럼 이름은 일치하지 않아도 됩니다.


입양 게시판에 동물 정보를 게시할 때, 이름이 없는 동물은 "No name"이라고 출력하도록 조회하는 문제입니다.

 

NULL일 때 ~하도록 처리하는 문장들은 여러 가지가 있죠. 저는 이번에 CASE WHEN과 COALESCE문을 사용해 정답 코드를 작성해보겠습니다.

 

1) CASE WHEN

  SELECT ANIMAL_TYPE,
         CASE WHEN NAME IS NULL
              THEN "No name"
              ELSE NAME 
         END AS NAME,
         SEX_UPON_INTAKE
    FROM ANIMAL_INS
ORDER BY ANIMAL_ID

 

2) COALESCE

  SELECT ANIMAL_TYPE, COALESCE(NAME, "No name") AS NAME, SEX_UPON_INTAKE
    FROM ANIMAL_INS
ORDER BY ANIMAL_ID

 

먼저 생각나는 건 CASE WHEN 구문인데, 실제로 짧은 건 COALESCE 구문이네요.

조건문 하면 생각나는 게 CASE WHEN이라 NULL 처리에는 COALESCE 구문이 더 편한 걸 자꾸 까먹습니다.