[MySQL] 시간/날짜에 관련 및 기타 함수들

JEONG SUJIN·2022년 12월 30일
0

데이터베이스

목록 보기
5/8

📍https://www.yalco.kr/lectures/sql/ 를 보면 공부하면서 정리한 것 입니다.

1. 시간/날짜 관련 함수들

함수설명
CURRENT_DATE, CURDATE현재 날짜 반환
CURRENT_TIME, CURTIME현재 시간 반환
CURRENT_TIMESTAMP, NOW현재 시간과 날짜 반환
SELECT CURDATE(), CURTIME(), NOW();

함수설명
DATE문자열에 따라 날짜 생성
TIME문자열에 따라 시간 생성
SELECT
  '2021-6-1' = '2021-06-01', -- 0
  DATE('2021-6-1') = DATE('2021-06-01'), -- 1
  '1:2:3' = '01:02:03', -- 0
  TIME('1:2:3') = TIME('01:02:03'); -- 1
함수설명
YEAR주어진 DATETIME값의 년도 반환
MONTHNAME주어진 DATETIME값의 월(영문) 반환
MONTH주어진 DATETIME값의 월 반환
WEEKDAY주어진 DATETIME값의 요일값 반환(월요일: 0)
DAYNAME주어진 DATETIME값의 요일명 반환
DAYOFMONTH, DAY주어진 DATETIME값의 날짜(일) 반환
SELECT
orderdate,
year(orderdate) as year,
monthname(orderdate) as monthname,
month (orderdate) as month,
weekday (orderdate) as weekday,
dayname (orderdate) as dayname,
day(orderdate) as day
FROM Orders;

select OrderDate,
CONCAT(
 CONCAT_WS(
 '/', 
 year(OrderDate), month(OrderDate), day(OrderDate)
), 
' ', 
UPPER(left(dayname(OrderDate), 3))
)
from Orders;

함수설명
HOUR주어진 DATETIME의 시 반환
MINUTE주어진 DATETIME의 분 반환
SECOND주어진 DATETIME의 초 반환
select hour(now()), minute(now()), second(now())

함수설명
ADDDATE, DATE_ADD시간/날짜 더하기
SUBDATE, DATE_SUB시간/날짜 빼기
SELECT 
  ADDDATE('2021-06-20', INTERVAL 1 YEAR),
  ADDDATE('2021-06-20', INTERVAL -2 MONTH),
  ADDDATE('2021-06-20', INTERVAL 3 WEEK),
  ADDDATE('2021-06-20', INTERVAL -4 DAY),
  ADDDATE('2021-06-20', INTERVAL -5 MINUTE),
  ADDDATE('2021-06-20 13:01:12', INTERVAL 6 SECOND);

함수설명
DATE_DIFF두 시간/날짜 간 일수차
TIME_DIFF두 시간/날짜 간 시간차
select 
OrderDate,
now(),
DATEDIFF(OrderDate, now())
from Orders;

함수설명
LAST_DAY해당 달의 마지막 날짜
SELECT
  OrderDate,
  LAST_DAY(OrderDate),
  DAY(LAST_DAY(OrderDate)),
  DATEDIFF(LAST_DAY(OrderDate), OrderDate)
FROM Orders;

함수설명
DATE_FORMAT시간/날짜를 지정한 형식으로 반환
형식설명
%Y년도 4자리
%y년도 2자리
%M월 영문
%m월 숫자
%D일 영문(1st, 2nd, 3rd...)
%d, %e일 숫자 (01 ~ 31)
%Thh:mm:ss
%rhh:mm:ss AM/PM
%H, %k시 (~23)
%h, %l시 (~12)
%i
%S, %s
%pAM/PM
SELECT
  DATE_FORMAT(NOW(), '%M %D, %Y %T'),
  DATE_FORMAT(NOW(), '%y-%m-%d %h:%i:%s %p'),
  DATE_FORMAT(NOW(), '%Y년 %m월 %d일 %p %h시 %i분 %s초');

함수설명
STR TO DATE(S, F)S를 F형식으로 해석하여 시간/날짜 생성

2. 기타 함수들

형식설명
IF(조건, T, F)조건이 참이라면 T, 거짓이면 F 반환
SELECT IF (1 > 2, '1는 2보다 크다.', '1은 2보다 작다.');

💡 보다 복잡한 조건은 CASE문을 사용합니다.

SELECT
CASE
  WHEN -1 > 0 THEN '-1은 양수다.'
  WHEN -1 = 0 THEN '-1은 0이다.'
  ELSE '-1은 음수다.'
END;
형식설명
IFNULL(A, B)A가 NULL일 시 B 출력
SELECT
  IFNULL('A', 'B'),
  IFNULL(NULL, 'B');
profile
기록하기

0개의 댓글