프로그래머스-SQL

[프로그래머스-SQL] 프로그래머스 SQL Level3 없어진 기록 찾기 MySQL

Doshisha 2022. 10. 7. 12:27

문제

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

 

프로그래머스

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

programmers.co.kr

풀이

서브쿼리에 NOT EXISTS 연산자를 이용해 문제를 해결할 수 있었다.

우리가 필요한 컬럼들은 ANIMAL_OUTS 테이블에 있으므로 메인쿼리에서 받아올 수 있도록 해주고 WHERE 절에 NOT EXISTS 연산자를 사용하여 ANIMAL_INS 테이블과 ANIMAL_OUTS 테이블의 ANIMAL_ID 상호존재여부를 파악할 수 있도록 쿼리를 작성해주면 문제를 해결할 수 있다. 

쿼리

SELECT 
    A.ANIMAL_ID,
    A.NAME
FROM 
    ANIMAL_OUTS AS A
WHERE 
    NOT EXISTS 
        (SELECT
            * 
        FROM 
            ANIMAL_INS AS B
        WHERE 
            B.ANIMAL_ID = A.ANIMAL_ID
        ORDER BY
            A.ANIMAL_ID 
        );