나이 정보가 없는 회원 수 구하기
https://school.programmers.co.kr/learn/courses/30/lessons/131528
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1) 문제
다음은 어느 의류 쇼핑몰에 가입한 회원 정보를 담은 USER_INFO 테이블입니다.
USER_INFO 테이블은 아래와 같은 구조로 되어있으며,
USER_ID, GENDER, AGE, JOINED는 각각 회원 ID, 성별, 나이, 가입일을 나타냅니다.
GENDER 컬럼은 비어있거나 0 또는 1의 값을 가지며 0인 경우 남자를, 1인 경우는 여자를 나타냅니다.
USER_INFO 테이블은 아래와 같은 구조로 되어있으며,
USER_ID, GENDER, AGE, JOINED는 각각 회원 ID, 성별, 나이, 가입일을 나타냅니다.
GENDER 컬럼은 비어있거나 0 또는 1의 값을 가지며 0인 경우 남자를, 1인 경우는 여자를 나타냅니다.
USER_INFO 테이블에서 나이 정보가 없는 회원이 몇 명인지 출력하는 SQL문을 작성해주세요.
이때 컬럼명은 USERS로 지정해주세요.
이때 컬럼명은 USERS로 지정해주세요.
User Information
Column name | Type | Nullable |
---|---|---|
USER_ID | INTEGER | FALSE |
GENDER | TINYINT(1) | TRUE |
AGE | INTEGER | TRUE |
JOINED | DATE | FALSE |
2) 예시
예를 들어 USER_INFO 테이블이 다음과 같다면
User Information
USER_ID | GENDER | AGE | JOINED |
---|---|---|---|
1 | 1 | 26 | 2021-06-01 |
2 | NULL | NULL | 2021-07-25 |
3 | 1 | NULL | 2021-07-30 |
4 | 0 | 31 | 2021-08-03 |
나이 정보가 없는 회원은 2명 이므로, 다음과 같은 결과가 나와야 합니다.
User Information
USER_ID |
---|
2 |
3) 풀이
1. 나이 정보가 NULL인 것
● WHERE AGE IS NULL
2. USER_INFO 테이블에서 모든 레코드의 수를 세아려 'USERS'라는 컬럼명으로 결과를 가져옵니다.
● SELECT COUNT(*) AS USERS FROM USER
4) 코드
SELECT COUNT(*) AS USERS FROM USER_INFO WHERE AGE IS NULL;
※ SUM을 이용한 방식도 있습니다.
SELECT SUM(AGE IS NULL) AS USERS FROM USER_INFO;
// 조건을 충족하는 참(True)은 곧 1을, 충족하지 못하는 거짓은 곧 0인 값이 나옵니다.
// SUM 함수 내에 있는 AGE IS NULL이라는 조건을 충족하는 경우에만 1로 변환되어 값이 더해집니다.
'Programmers Coding Test > MySQL' 카테고리의 다른 글
[프로그래머스 131114] MySQL - Level1 경기도에 위치한 식품창고 목록 출력하기 (0) | 2023.08.11 |
---|---|
[프로그래머스 131697] MySQL - Level1 가장 비싼 상품 구하기 (0) | 2023.08.11 |
[프로그래머스 59034] MySQL - Level1 모든 레코드 조회하기 (0) | 2023.08.09 |
[프로그래머스 59405] MySQL - Level1 상위 n개 레코드 (0) | 2023.08.09 |
[프로그래머스 59039] MySQL - Level1 이름이 없는 동물의 아이디 (0) | 2023.08.09 |