MySQL中时间日期类型的使用

一、MySQL中 日期和时间类型

参考 MySQL 数据类型(还有其他知识)

参考 SQL 数据类型

表示时间值的日期和时间类型为 DATETIME、DATE、TIMESTAMP、TIME和YEAR。

每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。

TIMESTAMP类型有专有的自动更新特性。

MySQL中 日期和时间类型
类型大小(字节)范围格式用途
DATE31000-01-01/9999-12-31YYYY-MM-DD日期值
TIME3'-838:59:59'/'838:59:59'HH:MM:SS时间值或持续时间
YEAR11901/2155YYYY年份值
DATETIME81000-01-01 00:00:00/9999-12-31 23:59:59YYYY-MM-DD HH:MM:SS混合日期和时间值
TIMESTAMP4

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/

<think>好的,我现在需要解决用户在MySQL中对DATE类型进行相减运算的问题。首先,用户的问题是如何在MySQL中对DATE类型进行相减,使用DATEDIFF函数。根据用户提供的引用,尤其是引用[2]和引用[4],我需要确认DATEDIFF的用法以及可能的其他方法。 首先,查看引用[2]提到DATEDIFF函数可以计算两个日期之间的天数差,并且DATEADD用于日期的加减。不过,用户的问题是相减,可能涉及两个日期之间的差异或者减去一个时间段。但用户特别提到DATEDIFF,所以可能需要重点讲解这个函数。 接下来,引用[4]中的例子是TO_DATE函数相减,但这似乎是Oracle的语法,因为MySQL使用DATEDIFF。因此需要指出MySQL中的正确方法是用DATEDIFF(end_date, start_date),返回的是天数差。 然后,用户可能还想知道如何减去一个时间段,比如减少几天。这时候需要使用DATE_SUB函数,如引用[1]中提到的date_sub()函数,或者使用INTERVAL关键字,例如date_column - INTERVAL 7 DAY。 需要分步骤说明两种情况:1. 计算两个日期之间的天数差,使用DATEDIFF;2. 对某个日期减去一段时间,使用DATE_SUB或减法操作符。 同时,需要确保示例正确,比如DATEDIFF的参数的顺序,以及DATE_SUB的语法是否正确。例如,DATEDIFF的结果是end_date - start_date,而DATE_SUB(date, INTERVAL expr unit)的用法。 另外,用户可能容易混淆DATEDIFF和TIMESTAMPDIFF,后者可以返回不同的单位(如小时、分钟)。但根据引用[2],DATEDIFF主要返回天数差,所以可能需要提到TIMESTAMPDIFF作为补充。 最后,生成相关问题,涵盖日期计算的其他常见需求,比如添加时间、计算时间差的其他单位等。</think>### MySQLDATE类型相减的方法 在MySQL中,对`DATE`类型进行相减运算主要有两种场景:**计算两个日期的间隔天数**和**对日期进行减法运算(减少特定时间单位)**。具体方法如下: --- #### 一、计算两个日期的间隔天数 使用`DATEDIFF(end_date, start_date)`函数,返回值为`end_date - start_date`的天数差。 **语法:** ```sql SELECT DATEDIFF('2023-10-10', '2023-10-05'); -- 结果为5 SELECT DATEDIFF('2023-10-05', '2023-10-10'); -- 结果为-5 ``` **注意:** - 参数顺序为`结束日期`在前,`开始日期`在后[^2]。 - 如果日期包含时间部分(如`DATETIME`类型),函数会自动忽略时间,仅计算日期部分。 --- #### 二、对日期进行减法运算(减少时间单位) 若需从某个日期中减去若干天、月或年,可以使用以下两种方式: 1. **`DATE_SUB(date, INTERVAL expr unit)`函数** **语法:** ```sql SELECT DATE_SUB('2023-10-10', INTERVAL 7 DAY); -- 结果为2023-10-03 SELECT DATE_SUB('2023-10-10', INTERVAL 1 MONTH); -- 结果为2023-09-10 ``` 2. **直接使用减法操作符** ```sql SELECT '2023-10-10' - INTERVAL 7 DAY; -- 结果为2023-10-03 SELECT '2023-10-10' - INTERVAL 1 MONTH; -- 结果为2023-09-10 ``` **支持的时间单位:** `DAY`(天)、`MONTH`(月)、`YEAR`(年)、`HOUR`(小时)、`MINUTE`(分钟)等[^1][^2]。 --- #### 三、扩展:计算其他时间单位差值 若需计算小时、分钟等更小单位的差值,可使用`TIMESTAMPDIFF(unit, start_date, end_date)`: ```sql SELECT TIMESTAMPDIFF(HOUR, '2023-10-05 08:00:00', '2023-10-05 12:30:00'); -- 结果为4(小时) ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值