Doby's Lab

Programmers: 없어진 기록 찾기 (MySQL) 본문

Data Engineering/SQL

Programmers: 없어진 기록 찾기 (MySQL)

도비(Doby) 2023. 9. 3. 03:00

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

 

프로그래머스

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

programmers.co.kr


Level 3

 

ANIMAL_OUTS에는 있지만, ANIMAL_INS에는 없는 동물을 찾는 문제였습니다.

이 부분에 대해서 핵심은 OUTSLEFT라고 한다면, LEFT OUTER JOIN을 해주고, NULL이 된 INS.ANIMAL_ID를 찾아 SELECT을 해주면 되는 문제였습니다.

 

또한, WHERE의 조건에서 필드에 대해 NULL인지 아닌지를 물을 때, 다른 value에 대해서는 =가 가능했으나, NULLis를 사용해야 한다는 점이 중요했습니다.

SELECT OUTS.ANIMAL_ID,
    OUTS.NAME
FROM ANIMAL_OUTS AS OUTS
LEFT OUTER JOIN ANIMAL_INS AS INS
ON OUTS.ANIMAL_ID = INS.ANIMAL_ID
WHERE INS.ANIMAL_ID is NULL
ORDER BY OUTS.ANIMAL_ID ASC

 

 

728x90