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

 

一、格式与区别

重点一:

1、DATE 是 年月日YYYY-MM-DD,

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

3、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个字节,实际格式,与时区无关

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

 ------------------------------------------------

  

二、定义

1、Timestamp

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

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

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

 

 

2、datetime

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

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

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

 

 

3、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'。要想确保不使用严格模式时日期有效,应检查应用程序。

 

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

 

 

 

 

     本文转自韩立伟 51CTO博客,原文链接:http://blog.51cto.com/hanchaohan/1751447,如需转载请自行联系原作者