[프로그래머스(Programmers)][SQL] GROUP BY (Lv2) 동명 동물 수 찾기

728x90

 

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

 

코딩테스트 연습 - 동명 동물 수 찾기

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

programmers.co.kr

 

 

동물 보호소에 들어온 동물 이름 중 두 번 이상 쓰인 이름해당 이름이 쓰인 횟수를 조회하는 SQL
( 이름이 없는 동물은 집계에서 제외하며, 결과는 이름 순으로 조회 )

 

SELECT NAME, COUNT(NAME) COUNT	# 4
FROM ANIMAL_INS					# 1
GROUP BY NAME						# 2
HAVING COUNT(NAME) > 1				# 3
-- HAVING COUNT > 1  /* MySQL 에서만 */
/* SELECT 문보다 먼저 실행되므로 원래는 별칭 사용 못 함 ( WHERE 절과 같이 ). 
그러나 기능이 확장되어 GROUP BY, HAVING, ORDER BY 절에서는 예외적으로 별칭 사용 가능 */
ORDER BY NAME;						# 5

 

( MySQL 에서 별칭 문제  https://dev.mysql.com/doc/refman/8.0/en/problems-with-alias.html  )

 

 

반응형