MySQL中有关当前日期及日期格式的操作

mysql获取当前时间,日期函数

  • 获得当前日期函数 date(now())
  • 获得当前时间函数 time(now())
  • 获得当前日期+时间(date + time)函数:sysdate()
  • MySQL 获得当前时间戳函数:current_timestamp, current_timestamp()

MySQL 日期转换函数、时间转换函数

把日期时间转化为字符串格式 date_format(date,format), time_format(time,format)

%S, %s 两位数字形式的秒( 00,01, …, 59)
%I, %i 两位数字形式的分( 00,01, …, 59)
%H 两位数字形式的小时,24 小时(00,01, …, 23)
%h 两位数字形式的小时,12 小时(01,02, …, 12)
%k 数字形式的小时,24 小时(0,1, …, 23)
%l 数字形式的小时,12 小时(1, 2, …, 12)
%T 24 小时的时间形式(hh:mm:ss)
%r 12 小时的时间形式(hh:mm:ss AM 或hh:mm:ss PM)
%p AM或PM
%W 一周中每一天的名称(Sunday, Monday, …, Saturday)
%a 一周中每一天名称的缩写(Sun, Mon, …, Sat)
%d 两位数字表示月中的天数(00, 01,…, 31)
%e 数字形式表示月中的天数(1, 2, …, 31)
%D 英文后缀表示月中的天数(1st, 2nd, 3rd,…)
%w 以数字形式表示周中的天数( 0 = Sunday, 1=Monday, …, 6=Saturday)
%j 以三位数字表示年中的天数( 001, 002, …, 366)
%U 周(0, 1, 52),其中Sunday 为周中的第一天
%u 周(0, 1, 52),其中Monday 为周中的第一天
%M 月名(January, February, …, December)
%b 缩写的月名( January, February,…., December)
%m 两位数字表示的月份(01, 02, …, 12)
%c 数字表示的月份(1, 2, …., 12)
%Y 四位数字表示的年份
%y 两位数字表示的年份
%% 直接值“%”

举例:
SELECT NOW();

SELECT YEAR(NOW());

SELECT TIME(NOW());

SELECT DATE_FORMAT(NOW(),'%Y年%m月%d日') AS 日期

SELECT DATE_FORMAT(hiredate,'%Y年%m月%d日') AS 日期 FROM emp; 
date_format('2020-08-10 21:21:21', '%Y%m%d%H%i%s') 
结果  20200810212121

把字符串转化成日期时间格式 str_to_date(str, format)

SELECT STR_TO_DATE('08/10/2020', '%m/%d/%Y'); -- 2020-08-10
SELECT STR_TO_DATE('08/10/20' , '%m/%d/%y');  -- 2020-08-10
SELECT STR_TO_DATE('08.10.2020', '%m.%d.%Y'); -- 2020-08-10
SELECT STR_TO_DATE('09:21:21', '%h:%i:%s');    -- 09:21:21
SELECT STR_TO_DATE('08.10.2020 09:21:21', '%m.%d.%Y %h:%i:%s');  -- 2020-08-10 09:21:21

MySQL (日期、天数)转换函数:to_days(date), from_days(days)

select to_days('0000-00-00'); -- 0
select to_days('2020-08-10'); -- 738012

MySQL (时间、秒)转换函数:time_to_sec(time), sec_to_time(seconds)

select time_to_sec('01:00:05'); -- 3605
select sec_to_time(3605); -- '01:00:05'

MySQL (Unix 时间戳、日期)转换函数

unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)

MySQL 日期时间计算函数

MySQL 为日期增加一个时间间隔:date_add()

set @dt = now();
select date_add(@dt, interval 1 day); -- add 1 day
select date_add(@dt, interval 1 hour); -- add 1 hour
select date_add(@dt, interval 1 minute); -- add 1 minute
select date_add(@dt, interval 1 second); -- add 1 second
select date_add(@dt, interval 1 microsecond); -- add 1 microsecond
select date_add(@dt, interval 1 week);  -- add 1 week
select date_add(@dt, interval 1 month);  -- add 1 month
select date_add(@dt, interval 1 quarter);  -- add 1 quarter
select date_add(@dt, interval 1 year);  -- add 1 year
select date_add(@dt, interval -1 day); -- sub 1 day

函数:sysdate()

sysdate() 日期时间函数跟 now() 类似,不同之处在于:now() 在执行开始时值就得到了, sysdate() 在函数执行时动态得到值。sysdate()函数两次得到的时间值相差 3秒。MySQL Manual 中是这样描述 sysdate()的:Return the time at which the functionexecutes。
sysdate() 日期时间函数,一般情况下很少用到。

获取当前日期(date)函数:curdate()

获得当前时间(time)函数:curtime()

SELECT CURDATE();-- 获取当前的年月日

SELECT CURTIME();-- 获取当前的时分秒

MySQL adddate(), addtime()函数,可以用 date_add() 来替代。

下面是 date_add() 实现 addtime() 功能示例:

select date_add(@dt, interval '01:15:30' hour_second);
结果  2020-08-10 21:32:21

MySQL 为日期减去一个时间间隔:date_sub()

MySQL date_sub() 日期时间函数 和 date_add() 用法一致,不再赘述。

MySQL 日期、时间相减函数:datediff(date1,date2), timediff(time1,time2)

MySQL timediff(time1,time2):两个日期相减 time1 - time2,返回 time 差值。注意:timediff(time1,time2) 函数的两个参数类型必须相同。

MySQL 时间戳(timestamp)转换、增、减函数

MySQL timestampdiff() 函数就比 datediff() 功能强多了,datediff() 只能计算两个日期(date)之间相差的天数。

MySQL 时区(timezone)转换函数

convert_tz(dt,from_tz,to_tz)
select convert_tz('2020-08-10 21:33:21', '+08:00', '+00:00'); -- 2020-08-10 05:33:21

时区转换也可以通过 date_add, date_sub, timestampadd 来实现。

select date_add('2020-08-10 21:33:21', interval -8 hour);
select date_sub('2020-08-10 21:33:21', interval 8 hour);
select timestampadd(hour, -8, '2020-08-10 21:33:21');

MySQL dayof… 函数:dayofweek(), dayofmonth(), dayofyear()分别返回日期参数,在一周、一月、一年中的位置。

MySQL week… 函数:week(), weekofyear(), dayofweek(), weekday(), yearweek()

MySQL weekday()函数和dayofweek()类似,都是返回“某天”在一周中的位置。不同点在于参考的标准, weekday:(0 =Monday, 1 = Tuesday, …, 6 = Sunday); dayofweek:(1 = Sunday, 2 = Monday,…, 7 = Saturday)

MySQL 返回星期和月份名称函数:dayname(), monthname()

MySQL last_day() 函数:返回月份中的最后一天。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值