코드 그라데이션

[얄코] MySQL 1-4. 시간, 날짜 관련 함수들 본문

Java/알고리즘

[얄코] MySQL 1-4. 시간, 날짜 관련 함수들

완벽한 장면 2023. 6. 9. 11:00

1. 시간, 날짜 관련 함수

 

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

1)

SELECT CURDATE(), CURTIME(), NOW();

실행 결과

 

 

함수 설명
DATE 문자열에 따라 날짜 생성
TIME 문자열에 따라 시간 생성

1)

SELECT
  '2021-6-1' = '2021-06-01',
  DATE('2021-6-1') = DATE('2021-06-01'),
  '1:2:3' = '01:02:03',
  TIME('1:2:3') = TIME('01:02:03');

실행 결과

 

 

2)

SELECT
  '2021-6-1 1:2:3' = '2021-06-01 01:02:03',
  DATE('2021-6-1 1:2:3') = DATE('2021-06-01 01:02:03'),
  TIME('2021-6-1 1:2:3') = TIME('2021-06-01 01:02:03'),
  DATE('2021-6-1 1:2:3') = TIME('2021-06-01 01:02:03'),
  DATE('2021-6-1') = DATE('2021-06-01 01:02:03'),
  TIME('2021-6-1 1:2:3') = TIME('01:02:03');

실행 결과

 

 

3)

SELECT * FROM Orders
WHERE
  OrderDate BETWEEN DATE('1997-1-1') AND DATE('1997-1-31');

실행 결과

 

 

함수 설명
HOUR 주어진 DATETIME의 시 반환
MINUTE 주어진 DATETIME의 분 반환
SECOND 주어진 DATETIME의  반환

1)

SELECT
  HOUR(NOW()), MINUTE(NOW()), SECOND(NOW());

실행 결과

 

 

 

함수 설명
YEAR 주어진 DATETIME 값의 연도 반환
MONTHNAME 주어진 DATETIME 값의 월(영문) 반환
MONTH 주어진 DATETIME 값의 월 반환
WEEKDAY 주어진 DATETIME값의 요일값 반환(월요일: 0)
DAYNAME 주어진 DATETIME값의 요일명 반환
DAYOFMONTH, DAY 주어진 DATETIME값의 날짜(일) 반환

1)

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;

실행 결과

 

 

2)

SELECT
  OrderDate,
  CONCAT(
    CONCAT_WS(
      '/',
      YEAR(OrderDate), MONTH(OrderDate), DAY(OrderDate)
    ),
    ' ',
    UPPER(LEFT(DAYNAME(OrderDate), 3))
  )
FROM Orders;

실행 결과

 

 

3)

SELECT * FROM Orders
WHERE WEEKDAY(OrderDate) = 0;

실행 결과

 

 

 

함수 설명
ADDDATE, DATE_ADD 시간/날짜 더하기
SUBDATE, DATE_SUB 시간/날짜 빼기

1)

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);

실행 결과

 

 

2)

SELECT
  OrderDate,
  ADDDATE(OrderDate, INTERVAL 1 YEAR),
  ADDDATE(OrderDate, INTERVAL -2 MONTH),
  ADDDATE(OrderDate, INTERVAL 3 WEEK),
  ADDDATE(OrderDate, INTERVAL -4 DAY),
  ADDDATE(OrderDate, INTERVAL -5 MINUTE)
FROM Orders;

실행 결과

 

 

 

함수 설명
DATE_DIFF 두 시간/날짜 간 일수차
TIME_DIFF 두 시간/날짜 간 시간차

1)

SELECT
  OrderDate,
  NOW(),
  DATEDIFF(OrderDate, NOW())
FROM Orders;

실행 결과

 

 

2)

SELECT
  TIMEDIFF('2021-06-21 15:20:35', '2021-06-21 16:34:41');

실행 결과

 

 

3)

SELECT * FROM Orders
WHERE
  ABS(DATEDIFF(OrderDate, '1996-10-10')) < 5;

실행 결과

 

 

 

함수 설명
LAST_DAY 해당 달의 마지막 날짜

1)

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)
%T hh:mm:ss
%r hh:mm:ss AM/PM
%H, %k 시(~23)
%h, %l 시(~12)
%i
%S, %s
%p AM/PM

1)

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초');

실행 결과

 

 

2)

SELECT REPLACE(
  REPLACE(
    DATE_FORMAT(NOW(), '%Y년 %m월 %d일 %p %h시 %i분 %초'),
    'AM', '오전'
  ),
  'PM', '오후'
)

실행 결과

 

 

 

 

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

1)

SELECT
  DATEDIFF(
    STR_TO_DATE('2021-06-04 07:48:52', '%Y-%m-%d %T'),
    STR_TO_DATE('2021-06-01 12:30:05', '%Y-%m-%d %T')
  ),
  TIMEDIFF(
    STR_TO_DATE('2021-06-04 07:48:52', '%Y-%m-%d %T'),
    STR_TO_DATE('2021-06-01 12:30:05', '%Y-%m-%d %T')
  );

실행 결과

 

 

2)

SELECT
  OrderDate,
  DATEDIFF(
    STR_TO_DATE('1997-01-01 13:24:35', '%Y-%m-%d %T'),
    OrderDate
  ),
  TIMEDIFF(
    STR_TO_DATE('1997-01-01 13:24:35', '%Y-%m-%d %T'),
    STR_TO_DATE(CONCAT(OrderDate, ' ', '00:00:00'), '%Y-%m-%d %T')
  )
FROM Orders;

실행 결과

 

 

 

2. 기타 함수들

형식  설명
IF(조건, T, F) 조건이 참이라면 T, 거짓이면 F 반환

1)

SELECT IF (1 > 2, '1는 2보다 크다.', '1은 2보다 작다.');

실행 결과

 

 

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

 

1)

SELECT
CASE
  WHEN -1 > 0 THEN '-1은 양수다.'
  WHEN -1 = 0 THEN '-1은 0이다.'
  ELSE '-1은 음수다.'
END;

실행 결과

 

 

2)

SELECT
  Price,
  IF (Price > 30, 'Expensive', 'Cheap'),
  CASE
    WHEN Price < 20 THEN '저가'
    WHEN Price BETWEEN 20 AND 30 THEN '일반'
    ELSE '고가'
  END
FROM Products;

실행 결과

 

 

 

 

형식 설명
IFNULL(A, B) A가 NULL일 시 B 출력

 

1)

SELECT
  IFNULL('A', 'B'),
  IFNULL(NULL, 'B');

실행 결과

 

 

 

728x90

'Java > 알고리즘' 카테고리의 다른 글

[Lv.0] 문자열 바꿔서 찾기  (0) 2023.06.10
[Lv.0] 로그인 성공?  (2) 2023.06.10
[얄코] MySQL 1-3. 숫자와 문자열을 다루는 함수들  (0) 2023.06.09
[Lv.0] 이어 붙인 수  (0) 2023.06.09
아스키 코드 관련  (0) 2023.06.09
Comments