mysql之DATETIME、DATE和TIMESTAMP简单了解

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

MySQL5的日期类型有三种:DATETIME、DATE和TIMESTAMP,除了DATE用来表示一个不带时分秒的是日期,另外两个都带时分秒。TIMESTAMP还可以精确到毫秒。


DATE 是 年月日YYYY-MM-DD,

DATETIME 是 年月日时分秒YYYY-MM-DD HH:MM:SS,

TIMESTAMP是 年月日时分秒YYYY-MM-DD HH:MM:SS。


然后就是区别,

DATETIME支持范围:'1000-01-01 00:00:00'到'9999-12-31 23:59:59'

TIMESTAMP支持范围:格式一样,但不能早于1970或晚于2037


DATETIME存储8个字节,实际格式,与时区无关

TIMESTAMP存储4个字节,UTC格式,时区转化


一:Timestamp

TIMESTAMP列类型的属性不固定,取决于MySQL版本和服务器运行的SQL模式。


1.一个表可以存在多个TIMESTAMP列,但只有一个列会根据数据更新而改变为数据库系统当前值。因此,一个表中有多个TIMESTAMP列是没有意义,实际上一个表只设定一个TIMESTAMP列。


2.TIMESTAMP列的默认值是CURRENT_TIMESTAMP常量值。当纪录数据发生变化的时候,TIMESTAMP列会自动将其值设定为CURRENT_TIMESTAMP。


二:datetime

当你需要同时包含日期和时间信息的值时则使用DATETIME类型。

支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'

MySQL以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。


三:date

当你只需要日期值而不需要时间部分时应使用DATE类型

支持的范围是'1000-01-01'到 '9999-12-31'。

MySQL用'YYYY-MM-DD'格式检索和显示DATE值。



四、日期格式转换

 

1、字符串转日期

select STR_TO_DATE('2010-03-03 16:41:16', '%Y-%m-%d %H:%i:%s')

 

2、日期转字符串

select DATE_FORMAT('2010-03-03 16:41:16', '%Y-%m-%d %H:%i:%s')

 

五、日期的中年月日时分秒星期月份等获取方法

 

select TIMESTAMP('2010-03-03 16:41:16'); 


select DATE('2010-03-03 16:41:16'); 


select YEAR('2010-03-03 16:41:16'); 


select MONTH('2010-03-03 16:41:16'); 


select DAY('2010-03-03 16:41:16'); 


select TIME('2010-03-03 16:41:16'); 


select CURTIME(); 


select CURDATE(); 


select CURRENT_DATE; 


select CURRENT_TIME; 


select CURRENT_TIMESTAMP;

 

六、日期的算术运算

 

相关的函数很多很多,用法也很简单,一看就会,建议查看MySQL参考手册。

mysql> SELECT DATE_ADD('1999-01-01', INTERVAL 1 DAY); 


                -> '1999-01-02' 


mysql> SELECT DATE_ADD('1999-01-01', INTERVAL 1 HOUR); 


                -> '1999-01-01 01:00:00' 


mysql> SELECT DATE_ADD('1998-01-30', INTERVAL 1 MONTH); 


                -> '1998-02-28'

 

七、日期的大小比较

 

拿着日当数字,拿着字符串当日期,呵呵,很简单的。

     and update_time > '2010-03-02 16:48:41' 

     and update_time <= '2010-03-03 16:51:58'



八、说明:

可以使用任何常见格式指定DATETIME、DATE和TIMESTAMP值:


'YYYY-MM-DD HH:MM:SS'或'YY-MM-DD HH:MM:SS'格式的字符串。允许“不严格”语法:任何标点符都可以用做日期部分或时间部分之间的间割符。例如,'98-12-31 11:30:45'、'98.12.31 11+30+45'、'98/12/31 11*30*45'和'98@12@31 11^30^45'是等价的。


'YYYY-MM-DD'或'YY-MM-DD'格式的字符串。这里也允许使用“不严格的”语法。例如,'98-12-31'、'98.12.31'、'98/12/31'和'98@12@31'是等价的。


'YYYYMMDDHHMMSS'或'YYMMDDHHMMSS'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523091528'和'970523091528'被解释为'1997-05-23 09:15:28',但'971122129015'是不合法的(它有一个没有意义的分钟部分),将变为'0000-00-00 00:00:00'。


'YYYYMMDD'或'YYMMDD'格式的没有间割符的字符串,假定字符串对于日期类型是有意义的。例如,'19970523'和'970523'被解释为 '1997-05-23',但'971332'是不合法的(它有一个没有意义的月和日部分),将变为'0000-00-00'。


YYYYMMDDHHMMSS或YYMMDDHHMMSS格式的数字,假定数字对于日期类型是有意义的。例如,19830905132800和830905132800被解释为 '1983-09-05 13:28:00'。


YYYYMMDD或YYMMDD格式的数字,假定数字对于日期类型是有意义的。例如,19830905和830905被解释为'1983-09-05'。


无效DATETIME、DATE或者TIMESTAMP值被转换为相应类型的“零”值('0000-00-00 00:00:00'、'0000-00-00'或者00000000000000)。


对于包括日期部分间割符的字符串值,如果日和月的值小于10,不需要指定两位数。'1979-6-9'与'1979-06-09'是相同的。同样,对于包括时间部分间割符的字符串值,如果时、分和秒的值小于10,不需要指定两位数。'1979-10-30 1:2:3'与'1979-10-30 01:02:03'相同。


=========================================================================

当指定日期值时请注意某些缺陷:


指定为字符串的值允许的非严格格式可能会欺骗。例如,值'10:11:12'由于‘:’间割符看上去可能象时间值,但如果用于日期上下文值则被解释为年'2010-11-12'。值'10:45:15'被转换为'0000-00-00'因为'45'不是合法月。


在非严格模式,MySQL服务器只对日期的合法性进行基本检查:年、月和日的范围分别是1000到9999、00到12和00到31。任何包含超出这些范围的部分的日期被转换成'0000-00-00'。请注意仍然允许你保存非法日期,例如'2002-04-31'。要想确保不使用严格模式时日期有效,应检查应用程序。


在严格模式,非法日期不被接受,并且不转换。





     本文转自韩立伟 51CTO博客,原文链接:http://blog.51cto.com/hanchaohan/1751447,如需转载请自行联系原作者


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL
926.【mysql】 date 函数
926.【mysql】 date 函数
53 3
|
2月前
|
关系型数据库 MySQL Docker
MySQL 5.7 timestamp类型设置default value为'0000-00-00 00:00:00'报错的解决方法
MySQL 5.7 timestamp类型设置default value为'0000-00-00 00:00:00'报错的解决方法
|
2月前
|
SQL 消息中间件 关系型数据库
Flink报错问题之mysql timestamp字段报错如何解决
Apache Flink是由Apache软件基金会开发的开源流处理框架,其核心是用Java和Scala编写的分布式流数据流引擎。本合集提供有关Apache Flink相关技术、使用技巧和最佳实践的资源。
|
2月前
|
SQL 存储 关系型数据库
【Mysql】The DATE, DATETIME, and TIMESTAMP Types
【Mysql】The DATE, DATETIME, and TIMESTAMP Types
44 0
|
4月前
|
存储 关系型数据库 MySQL
MySQL中的date、datetime、timestamp有什么区别?
MySQL中的date、datetime、timestamp有什么区别?
47 0
|
4月前
|
存储 关系型数据库 MySQL
【Mysql】The DATE, DATETIME, and TIMESTAMP Types(二)
【Mysql】The DATE, DATETIME, and TIMESTAMP Types
33 0
【Mysql】The DATE, DATETIME, and TIMESTAMP Types(二)
|
8天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
1月前
|
关系型数据库 MySQL 数据库连接
关于MySQL-ODBC的zip包安装方法
关于MySQL-ODBC的zip包安装方法
|
26天前
|
关系型数据库 MySQL 数据库
rds安装数据库客户端工具
安装阿里云RDS的数据库客户端涉及在本地安装对应类型(如MySQL、PostgreSQL)的客户端工具。对于MySQL,可选择MySQL Command-Line Client或图形化工具如Navicat,安装后输入RDS实例的连接参数进行连接。对于PostgreSQL,可以使用`psql`命令行工具或图形化客户端如PgAdmin。首先从阿里云控制台获取连接信息,然后按照官方文档安装客户端,最后配置客户端连接以确保遵循安全指引。
78 1
|
20天前
|
Ubuntu 关系型数据库 MySQL
Ubuntu 中apt 安装MySQL数据库
Ubuntu 中apt 安装MySQL数据库
65 0

推荐镜像

更多