MySQL中四种存储日期类型的比较与选择

在开始接触Java时也许会使用String存储字符串,但是比较占空间且效率态度,在日常开发中,MySql通常使用的日期类型有Date、Datetime、Timestamp、时间戳四种类型。

1.Date格式

Date的存储数据格式为:YYYY-MM-DD,它支持的范围为’1000-01-01’到’9999-12-31’,如果不需要存储时分秒的数据,那推荐用Date格式存储。

`work_date` date DEFAULT NULL COMMENT '工作日期',

在这里插入图片描述

2. Datetime格式和TimeStamp

Datetime的存储格式为:YYYY-MM-DD HH:MM:SS,它支持的范围为’1000-01-01 00:00:00’到’9999-12-31 23:59:59’,但是他不区分时区,即当你的时区更换之后,你从数据库中读取的时间是错误的。

而TimeStamp区分时区,Timestamp 类型字段的值会随着服务器时区的变化而变化,自动换算成相应的时间,即在不同时区,查询到同一个条记录此字段的值会不一样。

下面实际演示一下!

建表 SQL 语句:

CREATE TABLE `time_zone_test` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `date_time` datetime DEFAULT NULL,
  `time_stamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

插入数据:

INSERT INTO time_zone_test(date_time,time_stamp) VALUES(NOW(),NOW());

查看数据:

select date_time,time_stamp from time_zone_test;

结果:

date_timetime_stamp
2020-01-11 09:53:322020-01-11 09:53:32

修改当前会话的时区:

set time_zone=’+8:00’;

再次查看数据:

date_timetime_stamp
2020-01-11 09:53:322020-01-11 17:53:32

扩展:一些关于 MySQL 时区设置的一个常用 sql 命令

# 查看当前会话时区
SELECT @@session.time_zone;
# 设置当前会话时区
SET time_zone = 'Europe/Helsinki';
SET time_zone = "+00:00";
# 数据库全局时区设置
SELECT @@global.time_zone;
# 设置全局时区
SET GLOBAL time_zone = '+8:00';
SET GLOBAL time_zone = 'Europe/Helsinki';

Timestamp 只需要使用 4 个字节的存储空间,但是 DateTime 需要耗费 8 个字节的存储空间。但是,这样同样造成了一个问题,Timestamp 表示的时间范围更小。

  • DateTime :1000-01-01 00:00:00 ~ 9999-12-31 23:59:59
  • Timestamp: 1970-01-01 00:00:01 ~ 2037-12-31 23:59:59

3.时间戳

很多时候,我们也会使用 int 或者 bigint 类型的数值也就是时间戳来表示时间。

这种存储方式的具有 Timestamp 类型的所具有一些优点,并且使用它的进行日期排序以及对比等操作的效率会更高,跨系统也很方便,毕竟只是存放的数值。缺点也很明显,就是数据的可读性太差了,你无法直观的看到具体时间。

select UNIX_TIMESTAMP(‘2020-01-11 09:53:32’);

UNIX_TIMESTAMP(‘2020-01-11 09:53:32’)
1578707612

select FROM_UNIXTIME(1578707612);

FROM_UNIXTIME(1578707612)
2020-01-11 09:53:32
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值