초보 개발자의 이야기, 릿허브

[MySQL] 프로그래머스 SQL 중복 제거하기 본문

코딩테스트/📒 SQL

[MySQL] 프로그래머스 SQL 중복 제거하기

릿99 2021. 10. 6. 15:19
728x90
반응형
1. 문제이해

https://programmers.co.kr/learn/courses/30/lessons/59408?language=mysql 

 

코딩테스트 연습 - 중복 제거하기

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디

programmers.co.kr

 

위와 같은 정보를 가진 ANIMAL_INS 테이블에서

동물 보호소에 들어온 동물들의 이름이 몇개인지를 조회하는 SQL문을 작성하는 것이 목표이다.

단, 이름이 NULL인 경우는 집계하지 않으며, 중복되는 이름은 하나로 친다.

 

 

 

2. 문제풀이

 

ANIMAL_INS 테이블에서, 동물들의 이름의 개수를 세는 문제이다.

단, 이름이 NULL인 경우는 집계하지 않으며, 중복되는 이름은 하나로 친다는 조건이 있다.

 

이름이 NULL인 경우를 집계하지 않는다는 것은, WHERE 절의 NOT NULL 을 통해,

이름을 센다는 것은, SELECT 절의 COUNT,

그 중에서도 중복값은 허용하지 않음DISTINCT 를 통해 구현했다.

문법에 대한 자세한 설명은 아래를 통해 확인하자.

 

 

 

3. 정답
SELECT COUNT(DISTINCT NAME) AS "count"
FROM ANIMAL_INS
WHERE NAME IS NOT NULL

SELECT : 중복되지 않는 이름(DISTINCT NAME) 의 개수를 카운트(COUNT)

별칭(AS) 를 사용해 'count' 라고 따로 명명해줌.

FROM : ANIMAL_INS에서

WHERE : 이름(NAME)이 NULL 이 아니라는 조건 추가

 

NULL이 아니고, 중복값을 제거한 동물들의 이름이 몇개인지를 조회하는 SQL문으로,

SELECT 절의 COUNT를 이용해, DISTINCT NAME, 중복값을 제거한 이름을 세주었다.

그리고, WHERE 절의 IS NOT NULL 을 통해

NAME 중 NULL값이 아닌 조건을 충족하는 자료들만 조회하도록 했다.

 

이중, WHERE 절의 조건 중 하나인 NULL을 잠깐 보고 넘어가도록 하자.

WHERE 절의 NULL 조건에는 IS NULL, IS NOT NULL 이 있고, 사용법은 다음과 같다.

IS NULL : 컬럼이 NULL인 데이터를 조회 (컬럼A IS NULL)

IS NOT NULL : 컬럼이 NULL이 아닌 데이터를 조회 (컬럼A IS NOT NULL)

 

COUNT에 대한 간략한 설명은 이전 포스팅에 정리해놓았으니, 참고하자.

https://beginnerdeveloper-lit.tistory.com/79

 

[MySQL] 프로그래머스 SQL 동물 수 구하기

1. 문제이해 https://programmers.co.kr/learn/courses/30/lessons/59406 코딩테스트 연습 - 동물 수 구하기 ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구..

beginnerdeveloper-lit.tistory.com

 

 


이번 포스팅을 쓰면서도 느낀거지만..

최대한 빠른시일 내에 개괄적인 SQL문법에 대한 설명글을 하나 쓰는게 좋을 것 같다. 🤣

아무래도 C, C++과 같은 언어와는 다르게 자잘한 설명으로는 한계가 있는 것 같아서,

빠른 시일 내에 꼭 정리해서 링크를 달아놓던지 해야지..👩‍💻

 



 

 

 

728x90
반응형