MySQL中时间日期类型的使用
一、MySQL中 日期和时间类型
参考 MySQL 数据类型(还有其他知识)
参考 SQL 数据类型
表示时间值的日期和时间类型为 DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
TIMESTAMP类型有专有的自动更新特性。
类型 | 大小(字节) | 范围 | 格式 | 用途 |
---|---|---|---|---|
DATE | 3 | 1000-01-01/9999-12-31 | YYYY-MM-DD | 日期值 |
TIME | 3 | '-838:59:59'/'838:59:59' | HH:MM:SS | 时间值或持续时间 |
YEAR | 1 | 1901/2155 | YYYY | 年份值 |
DATETIME | 8 | 1000-01-01 00:00:00/9999-12-31 23:59:59 | YYYY-MM-DD HH:MM:SS | 混合日期和时间值 |
TIMESTAMP | 4 |
1970-01-01 00:00:00/2038 结束时间是第 2147483647 秒,北京时间 2038-1-19 11:14:07,格林尼治时间 2038年1月19日 凌晨 03:14:07 |
YYYYMMDD HHMMSS | 混合日期和时间值,时间戳 |
二、日期和时间类型的使用
开始使用的是 Mysql 5.5.47
创建表时出错了,遇到两个问题。。
问题一:
[Err] 1067 - Invalid default value for 'create_time'
查阅资料,原来是版本问题
在5.5到5.6.4版本里,对于DEFAULT CURRENT_TIMESTAMP 子句,只能TIMESTAMP类型列上指定。
而从5.6.5开始以后的版本,对于DEFAULT CURRENT_TIMESTAMP子句可以指定到TIMESTAMP或者DATETIME类型列上。
问题二:
想给一个类型为date字段设置一个default value(CURRENT_DATE,CURRENT_DATE(),NOW())但试了很久都不行。最后试了下 DEFAULT NULL 成功了,再试下 DEFAULT 1也成功了。最后网上查了一下资料,原因是date类型的default value 一定要是一个常量,不能是一个函数或者是表达式。所以不能给MySQL的date类型的列设置默认值。
三、TIMESTAMP和DATETIME比较
相同点:
两者都可用来表示YYYY-MM-DD HH:MM:SS 类型的日期。
不同点:
他们的的存储方式,大小(字节),表示的范围不同。
TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。
DATETIME,不做任何改变,基本上是原样输入和输出。
总结:TIMESTAMP和DATETIME 都可用来表示YYYY-MM-DD HH:MM:SS 类型的日期, 除了存储方式和存储范围以及大小不一样,没有太大区别。但对于跨时区的业务,TIMESTAMP更为合适。
四、时间与时间戳之间转换
有些应用生成的时间戳是比这个多出三位,是毫秒表示,如果要转换,需要先将最后三位去掉(标准的10位数字,如果是13位的话可以以除以1000的方式),否则返回NULL
#将时间转换为时间戳unix_timestamp
SELECT UNIX_TIMESTAMP('2019-02-22 13:25:07'); #1550813107#将时间戳转换为时间from_unixtime
SELECT FROM_UNIXTIME(1550813107); #2019-02-22 13:25:07#NOW
SELECT UNIX_TIMESTAMP(NOW()); #1550813420
SELECT FROM_UNIXTIME(1550813420); #2019-02-22 13:30:20
参考 MySQL的10位或13位时间戳获取,表示及13位时间戳的存储
五、按时间日期查询
然后我将 Mysql 改为 Mysql 5.7.17,升一下版本
参考 MySQL DATE_FORMAT() 函数
#MySQL 按时间日期查询
DROP TABLE IF EXISTS tb_test;
CREATE TABLE IF NOT EXISTS tb_test(id INT NOT NULL AUTO_INCREMENT COMMENT 'ID',name VARCHAR(100) DEFAULT NULL COMMENT '名称',create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',PRIMARY KEY (id)
) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8 COMMENT '时间测试表';#插入数据
INSERT INTO tb_test (name) VALUES
('luo'),
('lei'),
('luolei'),
('xing'),
('dxx');#修改数据
UPDATE tb_test SET name='luo1', update_time='2021-01-23' WHERE id=100;
UPDATE tb_test SET name='luo2', update_time='2022-02-23' WHERE id=101;
UPDATE tb_test SET name='luo3', update_time='2023-03-23' WHERE id=102;#根据年月日查数据
SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, '%Y-%m-%d')='2019-02-22';
#根据年月查数据
SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, '%Y-%m')='2021-01';
#根据年查数据
SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, '%Y')='2022';#根据日期区间查询数据,并排序
SELECT *FROM tb_test WHERE DATE_FORMAT(update_time, '%Y') BETWEEN '2019' AND '2023' ORDER BY update_time ASC;
个人网站欢迎来访
http://www.leixingke.com/
MySQL中时间日期类型的使用相关推荐
- 面试官问:mysql中时间日期类型和字符串类型的选择
摘要:MySQL中有多种表示时间日期的数据类型,主要有YEAR.TIME.DATE.DATETIME.TIMESTAMP等 本文分享自华为云社区<一针见血,mysql中时间日期类型和字符串类型的 ...
- ES 中时间日期类型 “yyyy-MM-dd HHmmss” 的完全避坑指南
文章目录 1.ES中的日期类型有何不同 2.案例 2.1 案例介绍 2.2 原理揭秘 3.路为何这么不平 4.又一个坑 5.总结 6.ES 的时间类型为什么这么难用,有没有什么办法可以解决? 7.更优 ...
- ES 中时间日期类型 “yyyy-MM-dd HH:mm:ss” 的完全避坑指南
文章目录 1.ES中的日期类型有何不同 2.案例 2.1 案例介绍 2.2 原理揭秘 3.路为何这么不平 4.又一个坑 5.总结 6.ES 的时间类型为什么这么难用,有没有什么办法可以解决? 7.更优 ...
- php mysql 时间字段_php – MySQL中各种日期/时间字段类型的优...
> TIMESTAMP存储在MySQL专有方法中(尽管它基本上只是一个由年,月,日,小时,分钟和秒组成的字符串),此外,只要插入或更改记录,TIMESTAMP类型的字段就会自动更新.显式字段值给 ...
- MySQL中的日期和时间类型
文章目录 1 MySQL中的日期和时间类型 1 MySQL中的日期和时间类型 日期与时间类型是为了方便在数据库中存储日期和时间而设计的,数据库有多种表示日期和时间的数据类型.其中,YEAR类型表示年, ...
- MySQL中的日期时间类型与格式化方式
[1]MySQL中的日期时间类型 MySQL中常用的几种时间类型有:date.datetime.time.year.timestamp 数据类型 占用字节 最小值 最大值 零值表示 date 4 10 ...
- mysql 时间日期类型 datetime、timestamp、date、time、year
MySQL中有多处表示日期的数据类型:YEAR.TIME.DATE.DTAETIME.TIMESTAMP.当只记录年信息的时候,可以只使用 YEAR 类型. 每一个类型都有合法的取值范围,当指定确定不 ...
- java和mysql之间的时间日期类型传递
摘自:http://blog.csdn.net/weinianjie1/article/details/6310770 MySQL(版本:5.1.50)的时间日期类型如下: datetime 8byt ...
- java 和mysql 时间_java和mysql之间的时间日期类型传递
mysql(版本:5.1.50)的时间日期类型如下: datetime 8bytes xxxx-xx-xx xx:xx:xx 1000-01-01 00:00:00到9999-12-31 23:59: ...
最新文章
- flash 绘图API:绘制基础的图形
- python中的引用_Python中的引用
- shell如何将标准错误输出重定向为标准输出
- [转]Cookie/Session机制详解
- [系统安全] 八.Windows漏洞利用之CVE-2019-0708复现及防御详解
- 五、畸变矫正—让世界不在扭曲
- CSS之Background-clip属性
- 计算机c语言二级试题及答案,计算机c语言二级考试试题及其答案.doc
- java c 转换_Java怎么转换c语言?
- java 两个list相等_java 怎么比较两个list是否相同
- 2017-2018网络攻防第四周作业
- DLL的Export和Import及extern
- 【Hinton论文翻译与理解】How to represent part-whole hierarchies in a neural network_202102
- 计算机视觉论文-2021-08-03
- MindManager2018,修改下载时间
- 微软软件工程 第一周博客作业
- python冒号亮红无效语法_新的python无效语法*更新
- AI遮天传 ML-集成学习
- ROS 几款IDE,一些小坑
- codeforces514
热门文章
- XTW100高速编程器WIN10驱动安装
- Aura Component Cope Snippets
- 《微信小程序七日谈》- 第七天:不要捡了芝麻丢了西瓜
- Blockathon2018(上海)顺利结束,9个项目打开区块链落地新思路
- android培训机构排名
- android 基础培训ppt,Android基础之内部培训.ppt
- 专访超脑链团队:公链比联盟链更适合赋能传统企业
- Tian Ji -- The Horse Racing(贪心+STL)
- wind10MySQL闪退什么密码_小编调解技术编辑应对win10系统Mysql输入密码后闪退的操作办法的解决教程...
- 网络技术——基础与5G