13.10 DATETIME
在本教程中,您将了解MySQL DATETIME数据类型以及如何使用一些方便的函数来有效地操作DATETIME类型数据。
MySQL DATETIME数据类型简介
MySQL DATETIME存储包含日期和时间的值。 当您从DATETIME列查询数据时,MySQL会以以下格式显示DATETIME值:
YYYY-MM-DD HH:MM:SS默认情况下,DATETIME的值范围为1000-01-01 00:00:00至9999-12-31 23:59:59。
DATETIME值使用5个字节进行存储。另外,DATETIME值可以包括格式为YYYY-MM-DD HH:MM:SS [.fraction]例如:2017-12-20 10:01:00.999999的尾数有小数秒。 当包含小数秒精度时,DATETIME值需要更多存储,如下表所示:
分数秒精度
存储(字节)
0
0
1,2
1
3,4
2
5,6
3
例如,2017-12-20 10:01:00.999999需要8个字节,2015-12-20 10:01:00需要5个字节,3个字节为.999999,而2017-12-20 10:01:00.9只需要6个字节,小数秒精度为1字节。
请注意,在MySQL 5.6.4之前,
DATETIME值需要8字节存储而不是5个字节。
MySQL DATETIME与TIMESTAMP类型
MySQL提供了另一种类似于DATETIME,叫作TIMESTAMP的时间数据类型。
TIMESTAMP需要4个字节,而DATETIME需要5个字节。 TIMESTAMP和DATETIME都需要额外的字节,用于分数秒精度。
TIMESTAMP值范围从1970-01-01 00:00:01 UTC到2038-01-19 03:14:07 UTC。 如果要存储超过2038的时间值,则应使用DATETIME而不是TIMESTAMP。
MySQL将TIMESTAMP存储在UTC(有时区)值中。 但是,MySQL存储DATETIME值是没有时区的。下面来看看看下面的例子。
首先,将当前连接的时区设置为+00:00。
接下来,创建一个名为timestamp_n_datetime的表,它由两列组成:ts和dt,这两列分别使用TIMESTAMP和DATETIME类型,如以下语句 -
然后,将当前日期和时间插入到timestamp_n_datetime表的ts和dt列中,如下语句所示 -
之后,从timestamp_n_datetime表查询数据,如下语句所示 -
执行上面查询语句,得到以下结果 -
DATETIME和TIMESTAMP列中的两个值相同。
最后,将连接的时区设置为+03:00,再次从timestamp_n_datetime表查询数据。
执行上面查询语句,得到以下结果 -
可以看到,ts列为TIMESTAMP数据类型的值变了。这是因为在更改时区时,TIMESTAMP列以UTC为单位存储日期和时间值,根据新时区调整TIMESTAMP列的值。
这意味着如果使用TIMESTAMP数据来存储日期和时间值,则在将数据库移动到位于不同时区的服务器时时间的值可能不一样,所以应该认真考虑这个问题。
MySQL DATETIME函数
以下语句使用NOW()函数将变量@dt设置为当前日期和时间。
要查询@dt变量的值,请使用以下SELECT语句:
执行上面查询语句,得到以下结果 -
MySQL DATE函数
要从DATETIME值提取日期部分,请使用DATE函数,如下所示:
如果希望根据日期查询数据,但是列中存储的数据是基于日期和时间,则此功能非常有用。
下面来看看看下面的例子。
假设您想知道在2017-11-05当天创建的行,请使用以下查询:
执行上面查询语句,得到以下结果 -
它不返回任何行记录。
这是因为created_at列不仅包含日期,还包含时间。要纠正它,请使用DATE函数,如下所示:
执行上面查询语句,得到以下结果 -
它按预期返回一行。 如果表有多行,MySQL必须执行全表扫描以查找与条件匹配的行。
MySQL TIME函数
要从DATETIME值中提取时间部分,可以使用TIME函数,如以下语句所示:
执行上面查询语句,得到以下结果 -
MySQL YEAR, QUARTER, MONTH, WEEK, DAY, HOUR,MINUTE和SECOND函数
要从DATETIME值获取年,季,月,周,日,小时,分和秒,可以使用以下语句中所示的函数:
执行上面查询语句,得到以下结果 -
MySQL DATE_FORMAT函数
要格式化DATETIME值,可以使用DATE_FORMAT函数。 例如,以下语句基于%H:%i:%s - %W%M%Y格式来格式化DATETIME值:
执行上面查询语句,得到以下结果 -
MySQL DATE_ADD函数
要将间隔添加到DATETIME值,请使用DATE_ADD函数,如下所示:
执行上面查询语句,得到以下结果 -
MySQL DATE_SUB函数
要从DATETIME值中减去一个间隔值,可以使用DATE_SUB函数,如下所示:
执行上面查询语句,得到以下结果 -
MySQL DATE_DIFF函数
要计算两个DATETIME值之间的差值,可以使用DATEDIFF函数。 请注意,DATEDIFF函数仅在计算中考虑DATETIME值的日期部分。
请参见以下示例。
首先,创建一个名为datediff_test的表,其中只有一个dt列,其数据类型为DATETIME。
其次,将一些行插入到datediff_test表中。
第三,使用DATEDIFF函数将当前日期时间与datediff_test表的每一行中的值进行比较。
执行上面查询语句,得到以下结果 -
在本教程中,您已经了解了MySQL DATETIME数据类型和一些有用的DATETIME函数。
Last updated
Was this helpful?