在开始接触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 |
本文介绍了MySQL中Date、Datetime、Timestamp三种日期时间类型及其区别。Date类型适合存储不包含时分秒的日期,而Datetime和Timestamp在时区处理上有所不同。Timestamp在时区变化时会自动调整,但其表示的时间范围有限。时间戳则是一种数值表示时间的方式,易于比较和排序,但可读性较差。文章还展示了如何在MySQL中进行时间戳转换的SQL操作。

8203

被折叠的 条评论
为什么被折叠?



