网站建设实战李静,外贸网站大全,外国网站后台设计,邯郸市中医院TIMESTAMP的取值范围小#xff0c;并且TIMESTAMP类型的日期时间在存储时会将当前时区的日期时间值转换为时间标准时间值#xff0c;检索时再转换回当前时区的日期时间值。
而DATETIME则只能反映出插入时当地的时区#xff0c;其他时区的人查看数据必然会有误差的。
DATETI…TIMESTAMP的取值范围小并且TIMESTAMP类型的日期时间在存储时会将当前时区的日期时间值转换为时间标准时间值检索时再转换回当前时区的日期时间值。
而DATETIME则只能反映出插入时当地的时区其他时区的人查看数据必然会有误差的。
DATETIME日期时间8字节。格式为YYYY-MM-DD HH:MM:SS取值范围1000-01-01 00:00:00 至 9999-12-31 23:59:59
TIMESTAMP时间戳4字节。格式为YYYY-MM-DD HH:MM:SS取值范围1970-01-01 00:0001 UTC 至 2038-01-19 03:14:07 UTC
创建一张表包含2种数据类型。如下
mysql create table tb_datetime(- num1 datetime,- num2 timestamp);
Query OK, 0 rows affected (1.25 sec)mysql desc tb_datetime;
---------------------------------------------
| Field | Type | Null | Key | Default | Extra |
---------------------------------------------
| num1 | datetime | YES | | NULL | |
| num2 | timestamp | YES | | NULL | |
---------------------------------------------
2 rows in set (0.00 sec)mysql insert into tb_datetime values (2023-2-28 21:21:12,2023-2-28 21:21:12);
Query OK, 1 row affected (0.14 sec)mysql select * from tb_datetime;
------------------------------------------
| num1 | num2 |
------------------------------------------
| 2023-02-28 21:21:12 | 2023-02-28 21:21:12 |
------------------------------------------
1 row in set (0.00 sec)
这个时候看到的数据是一样的。
接着修改时区信息
mysql set time_zone 9:00;
Query OK, 0 rows affected (0.00 sec)mysql select * from tb_datetime;
------------------------------------------
| num1 | num2 |
------------------------------------------
| 2023-02-28 21:21:12 | 2023-02-28 22:21:12 |
------------------------------------------
1 row in set (0.00 sec)
可以看到num2即TIMESTAMP类型的数据跟着时区变化了。