MySQL数据类型 -- 日期时间型

版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处。 https://blog.csdn.net/robinson_0612/article/details/82824107

在MySQL关系型数据库中,MySQL支持的数据类型非常丰富。它主要分为3大类,即:数值型,日期时间性,字符型。而实际上这三类数据类型可以进一步的细分扩展,可以根据业务需要选择最适合的一种。本文主要介绍日期时间类型,并演示其用法。

一、日期时间型 MySQL支持的日期时间类型可以进一步细分,即可以分为日期型,时间型,日期时间型,时间戳等。如下图所示:

二、日期时间型存储需求

三、日期时间型零值显示

四、日期时间型演示

mysql> show variables like 'version';
+---------------+------------+
| Variable_name | Value |
+---------------+------------+
| version | 5.7.22-log |
+---------------+------------+

mysql> CREATE TABLE tb_date_time
    -> (
    -> col1 date,
    -> col2 time,
    -> col3 datetime,
    -> col4 timestamp DEFAULT current_timestamp
    -> );
Query OK, 0 rows affected (0.17 sec)

mysql> select 'Leshami' as Author
    -> union all
    -> select 'http://blog.csdn.net/leshami';
+------------------------------+
| Author |
+------------------------------+
| Leshami |
| http://blog.csdn.net/leshami |
+------------------------------+

mysql> INSERT INTO tb_date_time(col1, col2, col3)
    -> VALUES (now(), now(), now());
Query OK, 1 row affected, 1 warning (0.03 sec)

mysql> SELECT * FROM tb_date_time;
+------------+----------+---------------------+---------------------+
| col1 | col2 | col3 | col4 |
+------------+----------+---------------------+---------------------+
| 2018-09-23 | 18:07:13 | 2018-09-23 18:07:13 | 2018-09-23 18:07:13 |
+------------+----------+---------------------+---------------------+
1 row in set (0.00 sec)

-- 查看系统日期时间
mysql> system date
Sun Sep 23 18:08:18 CST 2018

-- 在mysql层临时修改一下时区,假定在这里修改为+7时区
mysql> set time_zone='+7:00';
Query OK, 0 rows affected (0.00 sec)

-- 再次查看表,col4列上的时间则提前了一小时
-- 也即是时区会影响时间戳列

mysql> SELECT * FROM tb_date_time;
+------------+----------+---------------------+---------------------+
| col1 | col2 | col3 | col4 |
+------------+----------+---------------------+---------------------+
| 2018-09-23 | 18:07:13 | 2018-09-23 18:07:13 | 2018-09-23 17:07:13 |
+------------+----------+---------------------+---------------------+

注意对比TIMESTAMP与DATETIME
TIMESTAMP需要4个字节,而DATETIME需要5个字节。 
TIMESTAMP和DATETIME都需要额外的字节来获得小数秒的精度。
TIMESTAMP值的范围为1970-01-01 00:00:01 UTC至2038-01-19 03:14:07 UTC。 
如果要存储超过2038的时间值,则应使用DATETIME而不是TIMESTAMP。

-- 查看当前时间
mysql> SET @dt = NOW();
Query OK, 0 rows affected (0.03 sec)

mysql> SELECT @dt;
+---------------------+
| @dt |
+---------------------+
| 2018-09-23 18:08:28 |
+---------------------+
1 row in set (0.00 sec)

mysql> SELECT DATE(@dt);
+------------+
| DATE(@dt) |
+------------+
| 2018-09-23 |
+------------+
1 row in set (0.00 sec)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菜鸟致敬

提供免费MySQL数据库学习

最近买了一个服务器,放着也没有什么作用,于是搭建了MySQL 提供大家学习数据使用吧,想知道数据的用户信息请在后台回复MySQL 如果大家有其他想搭建的数据库环...

69590
来自专栏marsggbo

python混账的编码问题解决之道

下面的代码作用是修改文件的编码格式。代码很简单,但是也很牛逼(在我看来),这是在segment上找到的解决办法,废话不多说,直接上代码。 import cod...

19970
来自专栏程序猿

从0学习MySQL系列(三)概念篇

概要 ---- 在篇文章中提过:概念:数据库管理系统(Database Management System)一些语法的汇总点。 ...

32250
来自专栏用户2442861的专栏

关于sql中索引的优缺点(面试常考)

   原文       http://blog.csdn.net/dinglang_2009/article/details/5951428

25410
来自专栏PHP在线

MYSQL数据库设计的一些小技巧[转载]

常用数据操作语言DML笔记(select insert update delete) select 语句 高级的查询功能,见下面的详细内容 s...

41750
来自专栏GreenLeaves

Oracle Schema

1、这是Schema的definition: A schema is a collection of database objects (used by a u...

21560
来自专栏H2Cloud

游戏服务器ID生成器组件

游戏服务器程序中,经常需要生成全局的唯一ID号,这个功能很常用,本文将介绍一种通用ID生成组件。游戏服务器程序中使用此组件的场景有:  创建角色时,为其分配唯一...

64480
来自专栏轮子工厂

深入理解MySQL---数据库知识最全整理,这些你都知道了吗?

对于后端开发人员来说,经常会和数据打交道,今天总结下数据库相关的知识。包括MySQL,JDBC基础,JDBC进阶,MongoDB,性能优化等知识点。

11430
来自专栏杨建荣的学习笔记

MySQL创建表失败的问题

今天有一个朋友问我一个MySQL的建表问题,问题的现象是创建表失败,根据他的反馈,问题比较奇怪, CREATE TABLE XXX ..此处省略260多个字...

42970
来自专栏逸鹏说道

通过MySQL自动同步刷新Redis

在服务端开发过程中,一般会使用MySQL等关系型数据库作为最终的存储引擎,Redis其实也可以作为一种键值对型的数据库,但在一些实际场景中,特别是关系型结构并不...

2.2K100

扫码关注云+社区

领取腾讯云代金券