프로그래머스/DB(oracle)

프로그래머스(59046) 루시와 엘라 찾기 [ in ]

svdjcuwg4638 2023. 4. 2. 08:04

문제 설명

ANIMAL_INS 테이블은 동물 보호소에 들어온 동물의 정보를 담은 테이블입니다. ANIMAL_INS 테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, INTAKE_CONDITION, NAME, SEX_UPON_INTAKE는 각각 동물의 아이디, 생물 종, 보호 시작일, 보호 시작 시 상태, 이름, 성별 및 중성화 여부를 나타냅니다.

NAMETYPENULLABLE
ANIMAL_ID VARCHAR(N) FALSE
ANIMAL_TYPE VARCHAR(N) FALSE
DATETIME DATETIME FALSE
INTAKE_CONDITION VARCHAR(N) FALSE
NAME VARCHAR(N) TRUE
SEX_UPON_INTAKE VARCHAR(N) FALSE

동물 보호소에 들어온 동물 중 이름이 Lucy, Ella, Pickle, Rogan, Sabrina, Mitty인 동물의 아이디와 이름, 성별 및 중성화 여부를 조회하는 SQL 문을 작성해주세요.

예시

이때 결과는 아이디 순으로 조회해주세요. 예를 들어 ANIMAL_INS 테이블이 다음과 같다면

ANIMAL_IDANIMAL_TYPEDATETIMEINTAKE_CONDITIONNAMESEX_UPON_INTAKE
A373219 Cat 2014-07-29 11:43:00 Normal Ella Spayed Female
A377750 Dog 2017-10-25 17:17:00 Normal Lucy Spayed Female
A353259 Dog 2016-05-08 12:57:00 Injured Bj Neutered Male
A354540 Cat 2014-12-11 11:48:00 Normal Tux Neutered Male
A354597 Cat 2014-05-02 12:16:00 Normal Ariel Spayed Female

SQL문을 실행하면 다음과 같이 나와야 합니다.

ANIMAL_IDNAMESEX_UPON_INTAKE
A373219 Ella Spayed Female
A377750 Lucy Spayed Fema

 

풀이

SELECT
    animal_id ,
    name ,
    sex_upon_intake
FROM
    animal_ins
WHERE
    name in ('Lucy' , 'Ella' , 'Pickle' , 
                    'Rogan' , 'Sabrina','Mitty')
ORDER BY animal_id

where 에 in을 사용하여 name에 괄호안에 내용이 있으면 보여준다

 

대소문자 구분 없이 찾고 싶을땐 

SELECT
    animal_id ,
    name ,
    sex_upon_intake
FROM
    animal_ins
WHERE
    lower(name) in ('lucy' , 'ella' , 'pickle' , 
                    'rogan' , 'sabrina','mitty')
ORDER BY animal_id

name를 lower로 소문자로 변환한 후 뒤에 조건도 모두 소문자로 바꾸면 대소문자 구분없이 원하는 정보를 찾을 수 있다.