在开始接触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_time | time_stamp |
---|---|
2020-01-11 09:53:32 | 2020-01-11 09:53:32 |
修改当前会话的时区:
set time_zone=’+8:00’;
再次查看数据:
date_time | time_stamp |
---|---|
2020-01-11 09:53:32 | 2020-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 |