[프로그래머스] MYSQL / 3월에 태어난 여성 회원 목록 출력하기

2023. 11. 12. 21:29Coding/프로그래머스-SQL

문제링크

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

 

프로그래머스

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

programmers.co.kr

문제

소스코드

SELECT MEMBER_ID, MEMBER_NAME, GENDER, SUBSTR(DATE_OF_BIRTH, 1, 10) AS DATE_OF_BIRTH
FROM MEMBER_PROFILE 
WHERE (GENDER = 'W') AND (SUBSTR(DATE_OF_BIRTH, 6, 2)=03) AND (TLNO is not NULL) 
ORDER BY MEMBER_ID ASC;

여기서 DATE_OF_BIRTH 날짜열을 하나의 문자열로 본다.

그리고 SUBSTR() 함수의 기능을 사용한다. SUBSTR(인수1, 인수2, 인수3) 함수는 인수1이라는 문자열을 인수2부터 인수3만큼의 문자열을 쪼개는 기능을 가지고 있다. 생일이 3월인 여성 회원을 뽑을 때 여성회원이라는 조건을 추출하는 것은 어렵지 않지만, 생일이 3월이라는 것을 추출하는 것이 까다로워서 WHERE 조건절에서 SUBSTR()을 사용해 Month 부분만 추출한다.

이때 SELECT 문에서 SUBSTR(DATE_OF_BIRTH, 1, 10)을 쓴 이유가 궁금할 텐데 그냥 DATE_OF_BIRTH를 출력한다고 하면 날짜와 시간값까지 같이 출력이 되기 때문에 이를 방지하기 위해 날짜열 10번째에서 끊어준다고 생각하면 좋을 것 같다.