一、MySQL中 日期和时间类型
表示时间值的日期和时间类型为 DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
TIMESTAMP类型有专有的自动更新特性。
类型 |
大小(字节) |
范围 |
格式 |
用途 |
DATE |
3 |
1000-01-01/9999-12-31 |
YYYY-MM-DD |
日期值 |
TIME |
3 |
‘-838:59:59‘/‘838:59:59‘ |
HH:MM:SS |
时间值或持续时间 |
YEAR |
1 |
1901/2155 |
YYYY |
年份值 |
DATETIME |
8 |
1000-01-01 00:00:00/9999-12-31 23:59:59 |
YYYY-MM-DD HH:MM:SS |
混合日期和时间值 |
TIMESTAMP |
4 |
1970-01-01 00:00:00/2038结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07 |
YYYY-MM-DD HH:MM:SS |
混合日期和时间值,时间戳 |
二、TIMESTAMP和DATETIME比较
相同点:
两者都可用来表示YYYY-MM-DD HH:MM:SS 类型的日期。
不同点:
他们的的存储方式,大小(字节),表示的范围不同。
TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。
DATETIME,不做任何改变,基本上是原样输入和输出。
总结:
TIMESTAMP和DATETIME 都可用来表示YYYY-MM-DD HH:MM:SS 类型的日期, 除了存储方式和存储范围以及大小不一样,没有太大区别。但对于跨时区的业务,TIMESTAMP更为合适。
三、时间与时间戳之间转换:
有些应用生成的时间戳是比这个多出三位,是毫秒表示,如果要转换,需要先将最后三位去掉(标准的10位数字,如果是13位的话可以以除以1000的方式),否则返回NULL。
#将时间转换为时间戳unix_timestamp SELECT UNIX_TIMESTAMP(‘2019-10-24 20:16:07‘); #1571919367 #将时间戳转换为时间from_unixtime SELECT FROM_UNIXTIME(1571919367); #2019-10-24 20:16:07 #NOW SELECT UNIX_TIMESTAMP(NOW()); #1571919421 SELECT FROM_UNIXTIME(1571919421); #2019-10-24 20:17:01
四、按时间日期查询
#根据年月日查数据 SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, ‘%Y-%m-%d‘)=‘2019-02-22‘; #根据年月查数据 SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, ‘%Y-%m‘)=‘2021-01‘; #根据年查数据 SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, ‘%Y‘)=‘2022‘; #根据日期区间查询数据,并排序 SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, ‘%Y‘) BETWEEN ‘2019‘ AND ‘2023‘ ORDER BY update_time ASC;