티스토리 뷰
- 문제
- ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.
- ANIMAL_OUTS 테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, NAME, SEX_UPON_OUTCOME는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다. ANIMAL_OUTS 테이블의 ANIMAL_ID는 ANIMAL_INS의 ANIMAL_ID의 외래 키입니다.
- 천재지변으로 인해 일부 데이터가 유실되었습니다. 입양을 간 기록은 있는데, 보호소에 들어온 기록이 없는 동물의 ID와 이름을 ID 순으로 조회하는 SQL문을 작성해주세요.
- 풀이
- ANIMAL_OUTS 테이블에서 ANIMAL_INS 테이블에 없는 ANIMAL_ID와 NAME을 출력하면된다.
- 따라서, ANIMAL_OUTS테이블과 ANIMAL_INS의 ANIMAL_ID열에서 NULL값을 가진 테이블과 LEFT JOIN을 하면된다. 즉, ANIMAL_OUTS - ANIMAL_INS(차집합)를 구해주는 것과 같은 것임
- 답
SELECT ANIMAL_OUTS.ANIMAL_ID, ANIMAL_OUTS.NAME FROM ANIMAL_OUTS LEFT JOIN ANIMAL_INS ON ANIMAL_INS.ANIMAL_ID = ANIMAL_OUTS.ANIMAL_ID WHERE ANIMAL_INS.ANIMAL_ID IS NULL;
- 다른 방법
- NOT EXISTS 함수 사용하기: ANAIMAL_OUTS에서 ANIMAL_INS에 없는 값만 출력하기
SELECT ANIMAL_OUTS.ANIMAL_ID, ANIMAL_OUTS.NAME FROM ANIMAL_OUTS WHERE NOT EXISTS (SELECT DISTINCT ANIMAL_INS.ANIMAL_ID FROM ANIMAL_INS WHERE ANIMAL_INS.ANIMAL_ID = ANIMAL_OUTS.ANIMAL_ID)
- NOT IN 함수 사용하기: ANIMAL_OUTS에서 ANIMAL_INS의 ANIMAL_ID가 없는 값 출력하기
SELECT ANIMAL_OUTS.ANIMAL_ID, ANIMAL_OUTS.NAME FROM ANIMAL_OUTS WHERE ANIMAL_OUTS.ANIMAL_ID NOT IN (SELECT DISTINCT ANIMAL_INS.ANIMAL_ID FROM ANIMAL_INS)
- NOT EXISTS 함수 사용하기: ANAIMAL_OUTS에서 ANIMAL_INS에 없는 값만 출력하기
'SQL' 카테고리의 다른 글
[프로그래머스 SQL kit] 오랜 기간 보호한 동물(1) (0) | 2021.11.02 |
---|---|
[프로그래머스 SQL kit] 있었는데요 없었습니다 (0) | 2021.11.02 |
[프로그래머스 SQL kit] 중복 제거하기 (0) | 2021.11.02 |
[프로그래머스 SQL kit] 상위 n개 레코드 (0) | 2021.11.02 |
[프로그래머스 SQL kit] NULL 처리하기 (0) | 2021.11.01 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- R
- 그래프
- 코테
- 함수
- 스마트워치
- python
- 경제신문
- 경제
- 금리
- sql
- 영어
- 머신러닝
- 데이터분석
- 보안
- plot
- 개발
- SW
- 프로그래밍
- Programming
- 프로그래머스
- 영어회화
- 코딩테스트
- 파이썬
- 자바
- 클래스
- 모듈
- 데이터
- 코드
- 코딩
- mysql
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
글 보관함