코딩테스트/SQL

[프로그래머스][MySQL] Lv. 1 잔챙이 잡은 수 구하기

_알파카 2024. 6. 5. 17:10
728x90

문제

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

 

프로그래머스

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

programmers.co.kr

 

풀이

SELECT (COUNT(*) - COUNT(LENGTH)) AS FISH_COUNT
FROM FISH_INFO;

 

LENGTH 컬럼에서 NULL의 개수를 구하는 문제이다.

count(*)을 하면 전체 행의 개수가 나오지만, 

컬럼만을 지정하여 count를 계산하면, NULL 값이 제외된 값이 도출된다. 

따라서 NULL의 개수를 구하기 위해서는 count(*) - count(LENGTH)를 해주면 된다. 

 

다른 풀이 

SELECT COUNT(*) AS FISH_COUNT 
FROM FISH_INFO
WHERE LENGTH IS NULL;

 

728x90