MySQL中时间日期的问题

在项目开发中,往往会遇到时间日期的存储,而涉及到MySQL数据库,其中包含一些需要注意的点。

目录

时间日期类型建议使用date储存

DateTime和Timestamp的区别

时区信息

存储空间

使用时间戳存储时间



时间日期类型建议使用date储存

在开发中,有部分人会使用字符串的格式来存储时间日期,但从其数据类型大小来看,date所占用的字节数要少于varchar类型,并且对于一些需要使用操作时间日期的函数是无法使用的。对于日期参数使用date类型,或者需要时间日期,则使用Datetime。

DateTime和Timestamp的区别

这两种都属于MySQL的时间日期存储类型,其都可表示YYYY-MM-DD HH:MM:SS类型的时间。但两者之间还是有区别的。

时区信息

DateTime类型负责保存当前会话设置的时区所对应的时间,一旦所存储数据的数据库修改了时区,读取出来的参数时不正确的。

而Timestamp储存日期后,每次访问时会按照当前数据库的时区进行相关的计算。因此,针对与不同的时区读取出来的值是不同的。

下面通过数据库数据进行演示。

数据库表创建语句:

create table time_test(
    id int primary key auto_increment,
    date_time datetime not null,
    time_stamp timestamp not null
);

添加测试数据:

insert into time_test (date_time, time_stamp) VALUES (now(), now());

查看数据库表数据:

select * from time_test;

结果如下:

+----+---------------------+---------------------+
| id | date_time           | time_stamp          |
+----+---------------------+---------------------+
|  1 | 2021-07-10 20:39:01 | 2021-07-10 20:39:01 |
+----+---------------------+---------------------+

现在对数据库时区进行修改:

set time_zone = '+0:00';

再次对数据库表数据进行查询:

+----+---------------------+---------------------+
| id | date_time           | time_stamp          |
+----+---------------------+---------------------+
|  1 | 2021-07-10 20:39:01 | 2021-07-10 12:39:01 |
+----+---------------------+---------------------+

从结果中可以看到,DateTime类型的值不会根据数据库时区的变化而变化,而Timestamp会根据当前时区对数据进行更新修改。

存储空间

DateTime使用8个字节存储数据,并以实际格式为数据储存格式,其数据存储范围是1000-01-01 00:00:00 ~ 9999-12-31 23:59:59。

Timestamp使用4个字节存储数据,并以UTC(Universal Time Coordinated,协调世界时)为数据储存格式,其数据存储范围是1970-01-01 00:00:01 ~ 2037-12-31 23:59:59。

从存储数据的范围可以看出DateTime能够表示的时间范围更大。

使用时间戳存储时间

使用数值类型对时间日期进行储存,例如int,bigint。通过UNIX_TIMESTAMP函数将Timestamp类型的值进行转换。

使用时间戳来存储时间的优势是便于日期的排序及比较,并且效率更高。缺点是转换后的数据不易查看。

时间戳语句如下:

select UNIX_TIMESTAMP(now());

其结果为:

+-----------------------+
| UNIX_TIMESTAMP(now()) |
+-----------------------+
|            1625925300 |
+-----------------------+

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Edward.Li

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值