DB/Oracle

[Oracle] Programmers - 3월에 태어난 여성 회원 목록 출력하기

코딩마루 2025. 1. 28. 20:08

1. 문제

다음은 식당 리뷰 사이트의 회원 정보를 담은 MEMBER_PROFILE 테이블입니다. MEMBER_PROFILE 테이블은 다음과 같으며 MEMBER_ID, MEMBER_NAME, TLNO, GENDER, DATE_OF_BIRTH회원 ID, 회원 이름, 회원 연락처, 성별, 생년월일을 의미합니다.

MEMBER_PROFILE 테이블에서 생일이 3월여성 회원의 ID, 이름, 성별, 생년월일을 조회하는 SQL문을 작성해주세요. 이때 전화번호가 NULL인 경우는 출력대상에서 제외시켜 주시고, 결과는 회원ID를 기준으로 오름차순 정렬해주세요.


2. 풀이

SELECT MEMBER_ID, MEMBER_NAME, GENDER, TO_CHAR(DATE_OF_BIRTH, 'YYYY-MM-DD') AS DATE_OF_BIRTH
FROM MEMBER_PROFILE
WHERE 
    TLNO IS NOT NULL 
    AND GENDER = 'W'
    AND DATE_OF_BIRTH LIKE '%-MAR-%'
ORDER BY MEMBER_ID
  • TO_CHAR(): 날짜, 숫자 타입의 데이터를 (원본 데이터를 바꾸지 않고) 문자열로 변환하는 함수
    • TO_CHAR(SYSDATE, 'YYYY-MM-DD') → 2025-01-28

TO_CHAR()을 WHERE 문에 사용하여 아래와 같이 쿼리를 변경할 수 있다.

SELECT MEMBER_ID, MEMBER_NAME, GENDER, TO_CHAR(DATE_OF_BIRTH, 'YYYY-MM-DD') AS DATE_OF_BIRTH
FROM MEMBER_PROFILE
WHERE 
    TLNO IS NOT NULL 
    AND GENDER = 'W'
    AND TO_CHAR(DATE_OF_BIRTH, 'MM') = '03'
ORDER BY MEMBER_ID