首页 > 数据库技术 > 详细

Mysql中 Timestamp与Datetime的区别

时间:2020-01-16 13:27:36      阅读:68      评论:0      收藏:0      [点我收藏+]

Timestamp和Datetime的相同点:

1> 两者都可用来表示YYYY-MM-DD HH:MM:SS[.fraction]类型的日期。

 

TimestampDatetime的不同点:

1> 两者的存储方式不一样

(1)、TIMESTAMP列必须有默认值不能为null,如果默认是default null,则mysql自动为设置默认值“0000-00-00 00:00:00”。而 DATETIME列默认可为null。

 一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。

 

(2)、对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。

而对于DATETIME,不做任何改变,基本上是原样输入和输出。

 

下面 测试验证一下

首先创建两种测试表,一个使用timestamp格式,一个使用datetime格式。

技术分享图片
mysql> create table test(id int,hiredate timestamp);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test values(1,‘20151208000000‘);
Query OK, 1 row affected (0.00 sec)

mysql> create table test1(id int,hiredate datetime);
Query OK, 0 rows affected (0.01 sec)

mysql> insert into test1 values(1,‘20151208000000‘);
Query OK, 1 row affected (0.00 sec)

mysql> select * from test;
+------+---------------------+
| id   | hiredate            |
+------+---------------------+
|    1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.01 sec)

mysql> select * from test1;
+------+---------------------+
| id   | hiredate            |
+------+---------------------+
|    1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.00 sec)
技术分享图片

两者输出是一样的。

 

其次修改当前会话的时区

技术分享图片
mysql> show variables like ‘%time_zone%‘; 
+------------------+--------+
| Variable_name    | Value  |
+------------------+--------+
| system_time_zone | CST    |
| time_zone        | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)

mysql> set time_zone=‘+0:00‘;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from test;
+------+---------------------+
| id   | hiredate            |
+------+---------------------+
|    1 | 2015-12-07 16:00:00 |
+------+---------------------+
1 row in set (0.00 sec)

mysql> select * from test1;
+------+---------------------+
| id   | hiredate            |
+------+---------------------+
|    1 | 2015-12-08 00:00:00 |
+------+---------------------+
1 row in set (0.01 sec)
技术分享图片

上述“CST”指的是MySQL所在主机的系统时间,是中国标准时间的缩写,China Standard Time UT+8:00

通过结果可以看出,test中返回的时间提前了8个小时,而test1中时间则不变。这充分验证了两者的区别。

 

2> 两者所能存储的时间范围不一样

timestamp所能存储的时间范围为:‘1970-01-01 00:00:01.000000‘ 到 ‘2038-01-19 03:14:07.999999‘。

datetime所能存储的时间范围为:‘1000-01-01 00:00:00.000000‘ 到 ‘9999-12-31 23:59:59.999999‘。

 

3>总结

TIMESTAMP和DATETIME除了存储范围和存储方式不一样,没有太大区别。当然,对于跨时区的业务,TIMESTAMP更为合适。

Mysql中 Timestamp与Datetime的区别

原文:https://www.cnblogs.com/flameHe/p/12200366.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!