MySQL5的日期类型有三种:DATETIME、DATE和TIMESTAMP,除了DATE用来表示一个不带时分秒的是日期,另外两个都带时分秒。TIMESTAMP还可以精确到毫秒。


DATE 是 年月日YYYY-MM-DD,

DATETIME 是 年月日时分秒YYYY-MM-DD HH:MM:SS,

TIMESTAMP是 年月日时分秒YYYY-MM-DD HH:MM:SS。


然后就是区别,

DATETIME支持范围:'1000-01-01 00:00:00'到'9999-12-31 23:59:59'

TIMESTAMP支持范围:格式一样,但不能早于1970或晚于2037


DATETIME存储8个字节,实际格式,与时区无关 【现在最新的版本是5个字节!】

TIMESTAMP存储4个字节,UTC格式,时区转化


对于timestamp来说,如果储存时的时区和检索时的时区不一样,那么拿出来的数据也不一样。对于datetime来说,存什么拿到的就是什么。

有一个区别就是如果存进去的是NULLtimestamp会自动储存当前时间,而 datetime会储存 NULL

可以读一下这篇文章:https://segmentfault.com/a/1190000017393602


一:Timestamp

TIMESTAMP列类型的属性不固定,取决于MySQL版本和服务器运行的SQL模式。


1.一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。因此,一个表中有多个TIMESTAMP列是没有意义,实际上一个表只设定一个TIMESTAMP列。


2.TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当纪录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP。


二:datetime

当你需要同时包含日期和时间信息的值时则使用DATETIME类型。

支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'

MySQL以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。


三:date

当你只需要日期值而不需要时间部分时应使用DATE类型

支持的范围是'1000-01-01'到 '9999-12-31'。

MySQL用'YYYY-MM-DD'格式检索和显示DATE值。



四、日期格式转换

 

1、字符串转日期

select STR_TO_DATE('2010-03-03 16:41:16', '%Y-%m-%d %H:%i:%s')

 

2、日期转字符串

select DATE_FORMAT('2010-03-03 16:41:16', '%Y-%m-%d %H:%i:%s')

 

五、日期的中年月日时分秒星期月份等获取方法

 

select TIMESTAMP('2010-03-03 16:41:16'); 


select DATE('2010-03-03 16:41:16'); 


select YEAR('2010-03-03 16:41:16'); 


select MONTH('2010-03-03 16:41:16'); 


select DAY('2010-03-03 16:41:16'); 


select TIME('2010-03-03 16:41:16'); 


select CURTIME(); 


select CURDATE(); 


select CURRENT_DATE; 


select CURRENT_TIME; 


select CURRENT_TIMESTAMP;

 

六、日期的算术运算

 

相关的函数很多很多,用法也很简单,一看就会,建议查看MySQL参考手册。

mysql> SELECT DATE_ADD('1999-01-01', INTERVAL 1 DAY); 


                -> '1999-01-02' 


mysql> SELECT DATE_ADD('1999-01-01', INTERVAL 1 HOUR); 


                -> '1999-01-01 01:00:00' 


mysql> SELECT DATE_ADD('1998-01-30', INTERVAL 1 MONTH); 


                -> '1998-02-28'

 

七、日期的大小比较

 

拿着日当数字,拿着字符串当日期,呵呵,很简单的。

     and update_time > '2010-03-02 16:48:41' 

     and update_time <= '2010-03-03 16:51:58'



八、说明:

可以使用任何常见格式指定DATETIME、DATE和TIMESTAMP值:


'YYYY-MM-DD HH:MM:SS'或'YY-MM-DD HH:MM:SS'格式的字符串。允许“不严格”语法:任何标点符都可以用做日期部分或时间部分之间的间割符。例如,'98-12-31 11:30:45'、'98.12.31 11+30+45'、'98/12/31 11*30*45'和'98@12@31 11^30^45'是等价的。


'YYYY-MM-DD'或'YY-MM-DD'格式的字符串。这里也允许使用“不严格的”语法。例如,'98-12-31'、'98.12.31'、'98/12/31'和'98@12@31'是等价的。


'YYYYMMDDHHMMSS'或'YYMMDDHHMMSS'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523091528'和'970523091528'被解释为'1997-05-23 09:15:28',但'971122129015'是不合法的(它有一个没有意义的分钟部分),将变为'0000-00-00 00:00:00'。


'YYYYMMDD'或'YYMMDD'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523'和'970523'被解释为 '1997-05-23',但'971332'是不合法的(它有一个没有意义的月和日部分),将变为'0000-00-00'。


YYYYMMDDHHMMSS或YYMMDDHHMMSS格式的数字,假定数字对于日期类型是有意义的。例如,19830905132800和830905132800被解释为 '1983-09-05 13:28:00'。


YYYYMMDD或YYMMDD格式的数字,假定数字对于日期类型是有意义的。例如,19830905和830905被解释为'1983-09-05'。


无效DATETIME、DATE或者TIMESTAMP值被转换为相应类型的“零”值('0000-00-00 00:00:00'、'0000-00-00'或者00000000000000)。


对于包括日期部分间割符的字符串值,如果日和月的值小于10,不需要指定两位数。'1979-6-9'与'1979-06-09'是相同的。同样,对于包括时间部分间割符的字符串值,如果时、分和秒的值小于10,不需要指定两位数。'1979-10-30 1:2:3'与'1979-10-30 01:02:03'相同。


=========================================================================

当指定日期值时请注意某些缺陷:


指定为字符串的值允许的非严格格式可能会欺骗。例如,值'10:11:12'由于‘:’间割符看上去可能象时间值,但如果用于日期上下文值则被解释为年'2010-11-12'。值'10:45:15'被转换为'0000-00-00'因为'45'不是合法月。


在非严格模式,MySQL服务器只对日期的合法性进行基本检查:年、月和日的范围分别是1000到9999、00到12和00到31。任何包含超出这些范围的部分的日期被转换成'0000-00-00'。请注意仍然允许你保存非法日期,例如'2002-04-31'。要想确保不使用严格模式时日期有效,应检查应用程序。


在严格模式,非法日期不被接受,并且不转换。