一、日期,时间戳格式转换

在数据库中,时间的存储格式一般为时间戳,但这样对于使用人员不太方便,故在查询时可以先转换格式

1.1、FROM_UNIXTIME()

将时间戳转换为日期格式

> select from_unixtime(1654162618,'%Y-%m-%d %H:%i:%s');
+-----------------------------------------------+
| from_unixtime(1654162618,'%Y-%m-%d %H:%i:%s') |
+-----------------------------------------------+
| 2022-06-02 17:36:58 |
+-----------------------------------------------+
1 row in set (0.00 sec)

1.2、UNIX_TIMESTAMP ()

将日期转换为时间戳格式

> select unix_timestamp('2022-06-06 17:45:20');
+---------------------------------------+
| unix_timestamp('2022-06-06 17:45:20') |
+---------------------------------------+
| 1654508720 |
+---------------------------------------+
1 row in set (0.00 sec)

1.3、示例

查询5月25号到6月2号之间的数据

> select * from test where start_time >= UNIX_TIMESTAMP('2022-05-25 00:00:00') and start_time <= UNIX_TIMESTAMP('2022-06-02 23:59:59');

1.4、参数

  • %M 月名字(January……December)

  • %W 星期名字(Sunday……Saturday)

  • %D 有英语前缀的月份的日期(1st, 2nd, 3rd, 等等。)

  • %Y 年, 数字, 4 位

  • %y 年, 数字, 2 位

  • %a 缩写的星期名字(Sun……Sat)

  • %d 月份中的天数, 数字(00……31)

  • %e 月份中的天数, 数字(0……31)

  • %m 月, 数字(01……12)

  • %c 月, 数字(1……12)

  • %b 缩写的月份名字(Jan……Dec)

  • %j 一年中的天数(001……366)

  • %H 小时(00……23)

  • %k 小时(0……23)

  • %h 小时(01……12)

  • %I 小时(01……12)

  • %l 小时(1……12)

  • %i 分钟, 数字(00……59)

  • %r 时间,12 小时(hh:mm:ss [AP]M)

  • %T 时间,24 小时(hh:mm:ss)

  • %S 秒(00……59)

  • %s 秒(00……59)

  • %p AM或PM

  • %w 一个星期中的天数(0=Sunday ……6=Saturday )

  • %U 星期(0……52), 这里星期天是星期的第一天

  • %u 星期(0……52), 这里星期一是星期的第一天

  • %% 一个文字“%”。

二、获取当前时间,日期

now()可换成时间表达式,截取时间字段里需要的数据

mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2022-06-15 10:46:47 |
+---------------------+
1 row in set (0.00 sec) mysql> select curdate();
+------------+
| curdate() |
+------------+
| 2022-06-15 |
+------------+
1 row in set (0.00 sec) mysql> select curtime();
+-----------+
| curtime() |
+-----------+
| 10:46:59 |
+-----------+
1 row in set (0.00 sec) mysql> select week(now());
+-------------+
| week(now()) |
+-------------+
| 24 |
+-------------+
1 row in set (0.00 sec) mysql> select month(now());
+--------------+
| month(now()) |
+--------------+
| 6 |
+--------------+
1 row in set (0.00 sec) mysql> select quarter(now());
+----------------+
| quarter(now()) |
+----------------+
| 2 |
+----------------+
1 row in set (0.00 sec) mysql> select year(now());
+-------------+
| year(now()) |
+-------------+
| 2022 |
+-------------+
1 row in set (0.00 sec) mysql>

三、时间日期函数

3.1 DATE_ADD()

作用:用于向日期添加指定的时间间隔

语法: DATE_ADD(date, INTERVAL num type)

  1. date:时间格式,时间表达式,存储时间的字段
  2. num:时间间隔值,正数为加,负数为减
  3. type:时间间隔的单位:
    • day:  天
    • hour:     时
    • minute: 分钟
    • second: 秒
    • microsecond:毫秒
    • week:   周
    • month: 月
    • quarter:季度
    • year:    年
3.1.1 示例:

简单运算

mysql> select date_add(now(), interval 1 hour);
+----------------------------------+
| date_add(now(), interval 1 hour) |
+----------------------------------+
| 2022-06-14 17:09:28 |
+----------------------------------+
1 row in set (0.00 sec) mysql> select date_add('2022-06-07 23:54:12', interval -1 day);
+--------------------------------------------------+
| date_add('2022-06-07 23:54:12', interval -1 day) |
+--------------------------------------------------+
| 2022-06-06 23:54:12 |
+--------------------------------------------------+
1 row in set (0.00 sec) mysql>

作为执行时间的判断条件,获取前一天的数据

select
from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s') as 告警通知时间,
date_add(from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s'), interval -1 day) as 前一天
from
alarm_lists
where
notify_time >= UNIX_TIMESTAMP(date_add(now(), interval -2 day)) and notify_time <= UNIX_TIMESTAMP(date_add(now(), interval -1 day));

3.2 DATE_SUB()

作用:从日期减去指定的时间间隔

此函数与本文3.1 的DATE_ADD() 可以看到互为相反函数,作用语法,支持的type值基本相同,唯一是DATE_ADD() num 为正数时是相加,DATE_SUB() num 为正数时是相减

可参考3.1,在此不做过多叙述

示例:

mysql> select date_sub(now(),interval 1 day);
+--------------------------------+
| date_sub(now(),interval 1 day) |
+--------------------------------+
| 2022-06-14 10:25:42 |
+--------------------------------+
1 row in set (0.00 sec) mysql> select date_sub(now(),interval -1 day);
+---------------------------------+
| date_sub(now(),interval -1 day) |
+---------------------------------+
| 2022-06-16 10:25:46 |
+---------------------------------+
1 row in set (0.00 sec)

3.3 DATEDIFF()

作用:返回两个日期之间的天数,day1 - day2

注:只有值的日期部分参与计算

示例:

mysql> select datediff('2022-06-05 15:00:00','2022-06-04 20:00:00');
+-------------------------------------------------------+
| datediff('2022-06-05 15:00:00','2022-06-04 20:00:00') |
+-------------------------------------------------------+
| 1 |
+-------------------------------------------------------+
1 row in set (0.00 sec) mysql>

3.4 PERIOD_DIFF()

作用:返回两个日期之间的月数,day1 -day2

注:只有值的月数部分参与计算

示例:

mysql> SELECT PERIOD_DIFF(201903, 201803);
+-----------------------------+
| PERIOD_DIFF(201903, 201803) |
+-----------------------------+
| 12 |
+-----------------------------+
1 row in set (0.00 sec) mysql>

3.5 TIMEDIFF()

作用:返回两个时间之间的差值,date1 -date2

注:两值必须为相同类型的参数,否则返回NULL

示例:

mysql> select timediff('2022-06-05 15:00:00','2022-06-04 20:00:00');
+-------------------------------------------------------+
| timediff('2022-06-05 15:00:00','2022-06-04 20:00:00') |
+-------------------------------------------------------+
| 19:00:00 |
+-------------------------------------------------------+
1 row in set (0.00 sec) mysql> select timediff('15:00:00','14:55:30');
+---------------------------------+
| timediff('15:00:00','14:55:30') |
+---------------------------------+
| 00:04:30 |
+---------------------------------+
1 row in set (0.00 sec) mysql>

3.6 TIMESTAMPDIFF()

作用:返回两个时间表达式之间的差值,datetime_expr2 - datetime_expr1

语法: TIMESTAMPDIFF(unit,datetime_expr1,datetime_expr2)

注:datetime_expr1,datetime_expr2 可以是不同的数据类型,如date或datetime

  unit:结果的单位,整数型

    • day:  天
    • hour:     时
    • minute: 分钟
    • second: 秒
    • microsecond:毫秒
    • week:   周
    • month: 月
    • quarter:季度
    • year:    年

示例:

mysql> select timestampdiff(minute,'2022-06-05 12:00:00','2022-06-05 12:30:31') as t1,timestampdiff(minute,'2022-06-05 12:00:00','2022-06-05') as t2,timestampdiff(minute,'2022-06-05 12:00:00','2022-06-05 00:00:00') as t3;
+------+------+------+
| t1 | t2 | t3 |
+------+------+------+
| 30 | -720 | -720 |
+------+------+------+
1 row in set (0.00 sec) mysql>

相差时间:

mysql> SELECT NOW() 当前日期,DATE_ADD(NOW(),INTERVAL - 800 DAY) 历史日期,TIMESTAMPDIFF(DAY,DATE_ADD(NOW(), INTERVAL - 800 DAY),NOW()) AS 相差天数;
+---------------------+---------------------+--------------+
| 当前日期 | 历史日期 | 相差天数 |
+---------------------+---------------------+--------------+
| 2022-06-15 09:54:02 | 2020-04-06 09:54:02 | 800 |
+---------------------+---------------------+--------------+
1 row in set (0.00 sec) mysql>

两值相减作为判断条件:

if(TIMESTAMPDIFF(minute,from_unixtime(start_time, '%Y-%m-%d %H:%i:%s'),from_unixtime(end_time, '%Y-%m-%d %H:%i:%s')) > 5
and TIMESTAMPDIFF(minute,from_unixtime(start_time, '%Y-%m-%d %H:%i:%s'),from_unixtime(end_time, '%Y-%m-%d %H:%i:%s')) <= 10,1,0) as '5~10min',

3.7 TO_DAYS()

作用:返回一个从0年开始到指定日期之间相隔的天数,常用作于查询指定时间段内的所有数据

注:TO_DAYS()不适用于公历日历(1582)出现之前的值,因为它不考虑日历更改时丢失的日期。在1582年之前的日期(可能在其他地区的其他年份),此功能的结果不可靠。

  MySQL将日期中的两位数年份值转换为四位数形式 。例如, '2017-10-09'、 '17-10-09'和‘171009’被看作是相同的日期

示例:

mysql> select to_days(now());
+----------------+
| to_days(now()) |
+----------------+
| 738686 |
+----------------+
1 row in set (0.00 sec) mysql>

查询今天的数据(从今天到当前执行时间):

select
from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s')
from
alarm_lists
where
to_days(from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s')) = to_days(now())

昨天:

SELECT
from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s') as 告警通知时间
FROM
alarm_lists
WHERE
TO_DAYS(NOW()) - TO_DAYS(from_unixtime(notify_time, '%Y-%m-%d %H:%i:%s')) <= 1

3.8 DATE_FORMAT()

作用:以不同的格式显示日期/时间数据

语法: DATE_FORMAT(date,format)

支持的格式:参考本文1.4

示例:

mysql> select date_format(now(),'%b %d %Y %h:%i %p');
+----------------------------------------+
| date_format(now(),'%b %d %Y %h:%i %p') |
+----------------------------------------+
| Jun 15 2022 10:56 AM |
+----------------------------------------+
1 row in set (0.00 sec) mysql> select date_format(now(),'%m-%d-%Y');
+-------------------------------+
| date_format(now(),'%m-%d-%Y') |
+-------------------------------+
| 06-15-2022 |
+-------------------------------+
1 row in set (0.00 sec) mysql> select date_format(now(),'%d %b %y');
+-------------------------------+
| date_format(now(),'%d %b %y') |
+-------------------------------+
| 15 Jun 22 |
+-------------------------------+
1 row in set (0.00 sec) mysql> select date_format(now(),'%d %b %Y %T:%f');
+-------------------------------------+
| date_format(now(),'%d %b %Y %T:%f') |
+-------------------------------------+
| 15 Jun 2022 10:56:46:000000 |
+-------------------------------------+
1 row in set (0.00 sec) mysql>
MySQL [srestandard]> select date_format(now(),'%Y-%m-%d %H:%i:%S');
+----------------------------------------+
| date_format(now(),'%Y-%m-%d %H:%i:%S') |
+----------------------------------------+
| 2023-07-11 18:37:36 |
+----------------------------------------+
1 row in set (0.00 sec)

四、查询指定时间段的数据

mysql 时间日期函数很多,多结合函数来判断时间范围,查询自己想要的数据,多学多练,熟能生巧

4.1 当前时间

以下都是截取到当前时间作为时间范围,实际运用中,可定时执行,例每天晚上 00:05:00 执行,查询从几天前的 00:05:00 到今天的数据

今天:

select * from 表名 where to_days(时间字段名) = to_days(now());

昨天:

SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1

本周:

select * FROM 表名 WHERE YEARWEEK(date_format(start_time,'%Y-%m-%d')) = YEARWEEK(now());

上周:

SELECT * FROM 表名 WHERE YEARWEEK(date_format(start_time,'%Y-%m-%d')) = YEARWEEK(now())-1;

近30天:

SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名)

本月:

SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' )

上月:

SELECT * FROM 表名 WHERE PERIOD_DIFF( date_format( now( ) , '%Y%m' ) , date_format( 时间字段名, '%Y%m' ) ) =1

本季度:

select * from 表名 where QUARTER(create_date)=QUARTER(now())

上季度:

select * from 表名 where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));

本年:

select * from 表名 where YEAR(create_date)=YEAR(NOW());

去年:

select * from 表名 where year(create_date)=year(date_sub(now(),interval 1 year));

4.2 指定时间

昨天:

select * from t1 where notify_time >= unix_timestamp(date_sub(curdate(),interval 1 day)) and notify_time <= unix_timestamp(curdate()) 

前天:

notify_time >= unix_timestamp(date_sub(curdate(),interval 2 day)) and notify_time <= unix_timestamp(date_sub(curdate(),interval 1 day))

五、补充

5.1 获取当天零点,9点的时间,时间戳

5.1.1 获取当天零点,9点的时间
MySQL [srestandard]> select date_format(curdate(),'%Y-%m-%d %H:%i:%s');
+--------------------------------------------+
| date_format(curdate(),'%Y-%m-%d %H:%i:%s') |
+--------------------------------------------+
| 2023-04-13 00:00:00 |
+--------------------------------------------+
1 row in set (0.00 sec) MySQL [srestandard]> select date_add(curdate(), interval 9 hour);
+--------------------------------------+
| date_add(curdate(), interval 9 hour) |
+--------------------------------------+
| 2023-04-13 09:00:00 |
+--------------------------------------+
1 row in set (0.00 sec) MySQL [srestandard]>
5.1.2 获取昨天零点,9点的时间
#昨日零点
select date_format(date_sub(curdate(),interval 1 day),'%Y-%m-%d %H:%i:%s'); #昨日9点
select date_add(date_sub(curdate(),interval 1 day), interval 9 hour);
5.1.3 获取当天零点,9点的时间戳
#零点
select unix_timestamp(curdate()); #9点
select unix_timestamp(date_add(curdate(), interval 9 hour));

昨天零点的时间戳

select unix_timestamp(date_sub(curdate(),interval 1 day));

昨天9点的时间戳

select unix_timestamp(date_add(date_sub(curdate(),interval 1 day), interval 9 hour));

5.2 数据插入时自动更新时间

  • DEFAULT CURRENT_TIMESTAMP:这个子句用于指定一个字段的默认值为当前的日期和时间。当插入一行但没有为该字段提供值时,MySQL 将自动使用当前的日期和时间填充该字段
  • ON UPDATE CURRENT_TIMESTAMP:这个子句用于指定一个字段在更新时自动更新为当前的日期和时间。当更新一行并更改该字段时,MySQL 将自动使用当前的日期和时间更新该字段

例:

建表:

CREATE TABLE `table_name` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`column1` varchar(255) DEFAULT NULL,
`column2` varchar(255) DEFAULT NULL,
`created_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP,
`updated_at` timestamp NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4

插入两条数据:

MySQL [sredev]> insert into table_name (column1,column2) values ('t1','t1');
Query OK, 1 row affected (0.23 sec) MySQL [sredev]> select * from table_name;
+----+---------+---------+---------------------+------------+
| id | column1 | column2 | created_at | updated_at |
+----+---------+---------+---------------------+------------+
| 1 | t1 | t1 | 2023-12-11 15:06:02 | NULL |
+----+---------+---------+---------------------+------------+
1 row in set (0.00 sec) MySQL [sredev]> insert into table_name (column1,column2) values ('t2','t2');
Query OK, 1 row affected (0.09 sec) MySQL [sredev]> select * from table_name;
+----+---------+---------+---------------------+------------+
| id | column1 | column2 | created_at | updated_at |
+----+---------+---------+---------------------+------------+
| 1 | t1 | t1 | 2023-12-11 15:06:02 | NULL |
| 2 | t2 | t2 | 2023-12-11 15:06:09 | NULL |
+----+---------+---------+---------------------+------------+
2 rows in set (0.00 sec)

更新两条数据:

MySQL [sredev]> update table_name set column1 = 't3';
Query OK, 2 rows affected (0.19 sec)
Rows matched: 2 Changed: 2 Warnings: 0 MySQL [sredev]> select * from table_name;
+----+---------+---------+---------------------+---------------------+
| id | column1 | column2 | created_at | updated_at |
+----+---------+---------+---------------------+---------------------+
| 1 | t3 | t1 | 2023-12-11 15:06:02 | 2023-12-11 15:08:08 |
| 2 | t3 | t2 | 2023-12-11 15:06:09 | 2023-12-11 15:08:08 |
+----+---------+---------+---------------------+---------------------+
2 rows in set (0.00 sec)

Mysql--日期,时间相关的更多相关文章

  1. android内部培训视频_第三节(3)_常用控件(ViewPager、日期时间相关、ListView)

    第三节(2):常用控件之ViewPager.日期时间相关.ListView  一.ViewPager 实例:结合PagerAdapter滑动切换图片  二.日期时间相关:AnalogClock\Dig ...

  2. MySQL 日期、时间转换函数

    MySQL 日期.时间转换函数:date_format(date,format), time_format(time,format) 能够把一个日期/时间转换成各种各样的字符串格式.它是 str_to ...

  3. mysql 日期函数总结

    1.0 格式化:DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据. 语法 DATE_FORMAT(date,format) date 参数是合法的日期.format 规定日期/时间的 ...

  4. mysql 日期加减操作

    1. MySQL 为日期增加一个时间间隔:date_add() set @dt = now(); select date_add(@dt, interval 1 day);        -- add ...

  5. mysql日期加减<转>

    1. MySQL 为日期增加一个时间间隔:date_add() set @dt = now(); select date_add(@dt, interval 1 day); - 加1天 select ...

  6. Mysql日期时间大全

    MySQL日期时间函数大全 DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,--7=星期六,ODBC标准)mysql> select DAYOFWEEK('1 ...

  7. mysql 日期类型比较

    MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型        存储空间       日期格式                 日期范围 ------------ ------ ...

  8. MySQL日期 字符串 时间戳互转

    平时比较常用的时间.字符串.时间戳之间的互相转换,虽然常用但是几乎每次使用时候都喜欢去搜索一下用法:本文将作为一个笔记,整理一下三者之间的 转换(即:date转字符串.date转时间戳.字符串转dat ...

  9. MySQL日期数据类型、时间类型使用总结

    MySQL日期数据类型.时间类型使用总结 MySQL日期数据类型.MySQL时间类型使用总结,需要的朋友可以参考下.   MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型    ...

  10. MySQL日期时间函数大全(转)

    MySQL日期时间函数大全 DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1 ...

随机推荐

  1. 🔥🔥想快速进入人工智能领域的Java程序员?你准备好了吗?

    引言 今天我们来探讨一下作为Java程序员,如何迅速融入人工智能的领域.,当前有一些流行的LLMs选择,例如ChatGPT.科大讯飞的星火.通义千问和文心一言等.如果你还没有尝试过这些工具,那么现在也 ...

  2. 龙芯发布 .NET 8 SDK 8.0.100-ea1(试用版)

    随着.NET 8的发布,国内的社区朋友们也很关心龙芯.NET 团队对于Loongarch .NET 8的发布时间,目前从龙芯.NET编译器团队已经在龙芯.NET 官网上发布龙芯.NET 8 SDK-8 ...

  3. 《HelloGitHub》第 92 期

    兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. https://github.com/521xueweiha ...

  4. Serializable是什么?为什么在Entity层要实现Serializable接口

    我在做房产信息管理系统时用到了Serializable接口 Serializable含义: 一个对象序列化的接口,一个类只有实现了Serializable接口,它的对象才能被序列化. Serializ ...

  5. 最小生成树(Prim、Kruskal)

    MST 引入 现在有一个连通图,他有\(N\)个节点,\(M\)条边 当我们砍掉一些边时,它会变成一棵树,其剩下的边权之和即为这棵树的权,当剩下的权值最小时,称这棵树为此图的最小生成树,即MST 模版 ...

  6. 使用C++和QT实现Log自定义日志系统

    MyLog 说明 使用QT的qInstallMessageHandler函数结合qDebug,qInfo实现自定义的日志系统 输出日志到文件和控制台 自动检测日志文件大小 自动更新日志文件修改日期 自 ...

  7. flask的cookie和session会话保持

    Cookie 获取请求cookie 通过请求对象中的cookies属性可以获取cookie. 实例: from flask import Flask, request @app.route(" ...

  8. 【Python】【OpenCV】定位条形码(一)

    关于二维码和条形码的检测和识别,在OpenCV中已经有提供了对应的API,cv2.QRCodeDetector() | cv2.barcode_BarcodeDetector() ,相关的实现极其简单 ...

  9. ElasticSearch之cat task management API

    命令样例如下: curl -X GET "https://localhost:9200/_cat/tasks?v=true&pretty" --cacert $ES_HOM ...

  10. 【JVM】一文掌握JVM垃圾回收机制

    作为Java程序员,除了业务逻辑以外,随着更深入的了解,都无法避免的会接触到JVM以及垃圾回收相关知识.JVM调优是一个听起来很可怕,实际上很简单的事. 感到可怕,是因为垃圾回收相关机制都在JVM的C ...