프로그래머스에서 SQL 문제를 풀면서 나왔던 함수들을 정리해 보았다.
☑️SQL 함수/필터링 기능 예시
✅ IS NULL / IS NOT NULL
: WHERE 컬럼명 IS NOT NULL
위 SQL문의 경우 컬럼명이 NULL이 아닌 데이터만 조회한다.
✅ LIKE
: WHERE 컬럼명 LIKE "글자 형식"
WHERE 절의 조건으로 문자열 타입에 대해 더 구체적인 조건으로 필터링할 때 사용한다.
예를 들어 특정 단어를 포함하는 경우에도 글자 형식을 잘 지정해서 사용할 수 있다. 아래 SQL문은 ADDRESS의 값이 서울-로 시작하는 레코드만 조회한다.
WHERE ADDRESS LIKE "서울%"
LIKE의 자세한 사용에 대해서는 문서를 참고하자.
LIKE는 주로 어떤 단어를 앞이나 뒤에 포함하는 레코드를 필터링할 때 많이 사용된다.
"단어%" : '단어'로 시작하는 레코드
"%단어" : '단어'로 끝나는 레코드
"%단어%" : '단어'를 포함하는 레코드
✅ DATE_FORMAT
: DATE_FORMAT(컬럼명, "바꾸려는 형식")
컬럼이 날짜 타입일 경우 문제에서 요구하는 출력 형식이 따로 있을 때 주로 사용한다.
예를 들어 '2022-03-05 01:13:00' 인 날짜 형식을 '2022-03-05'로 출력해야 하는 경우가 있다.
두 번째 매개변수에서는 날짜 타입의 컬럼명을 어떤 형식으로 출력하고 싶은지를 명시해 준다. 자세한 정보는 공식문서에 나와 있지만 많이 사용되는 값들은 정해져 있다. 대소문자가 구별되니 주의하자.
%Y: 연도를 4자리 값으로 출력
%m: 월을 숫자로 출력
%d: 일을 숫자로 출력
앞선 예시처럼 출력하려면 다음과 같이 입력하면 된다.
DATE_FORMAT(DATETIME, "%Y-%m-%d")
✅ YEAR, MONTH, DAY
: YEAR(컬럼명), MONTH(컬럼명), DAY(컬럼명)
날짜 데이터에서 년, 월, 일 데이터를 추출해 준다. 시간이나 분 정보를 추출해 주는 함수(HOUR, MINUTE 등)도 있지만 위의 함수들이 더 많이 쓰인다.
# DATETIME = '2022-05-26'
YEAR(DATETIME) # 2022
MONTH(DATETIME) # 5
DAY(DATETIME) # 26
✅ IFNULL
: IFNULL(컬럼명, "출력할 값")
NULL값인 데이터를 다른 값으로 출력해 준다.
아래 예시의 경우 NAME의 값이 NULL이면 "NO NAME"으로, NULL이 아니면 원래 값으로 출력한다.
IFNULL(NAME, "NO NAME")
✅ MAX, MIN
: MAX(컬럼명), MIN(컬럼명)
해당 컬럼에서 가장 큰 값, 가장 작은 값을 출력해 준다.
아래 예시의 경우 STUDENT_SCORE 테이블의 SCORE 컬럼 데이터들 중 가장 큰 값을 출력하고, 이때 컬럼 이름은 MAX_SCORE로 출력한다.
SELECT MAX(SCORE) AS MAX_SCORE FROM STUDENT_SCORE
✅ SUM, AVG, COUNT
: SUM(컬럼명), AVG(컬럼명), COUNT(컬럼명)
해당 컬럼의 합, 평균, 레코드 개수를 구할 수 있다.
아래 예시의 경우 STUDENT_SCORE 테이블의 SCORE 컬럼 데이터들의 평균값을 반올림한 값을 보여주고, 컬럼 이름은 AVG_SCORE로 출력한다.
SELECT ROUND(AVG(SCORE)) AS AVG_SCORE FROM STUDENT_SCORE
참고한 포스트
https://www.w3schools.com/sql/sql_like.asp
'server-side > SQL' 카테고리의 다른 글
SQL 기본 문법 정리 (0) | 2023.03.05 |
---|