服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySql日期查询数据的实现

MySql日期查询数据的实现

2023-05-31 14:43林卓淇 Mysql

本文主要介绍了MySql日期查询数据的实现,详细的介绍了几种日期函数的具体使用,及其具体某天的查询,具有一定的参考价值,感兴趣的可以了解一下

日期函数解析

date_format()
格式化日期格式,“date_format(时间戳,时间格式)”

date_sub()
从日期减去指定的时间间隔;函数形式DATE_SUB(date,INTERVAL expr type),date 参数是合法的日期表达式。expr 参数是您希望添加的时间间隔,时间间隔参数非常全面,常用的为 年月日时分秒;

?
1
2
3
4
//减天数
date_sub(时间,INTERVAL 1 DAY)
//减月份
date_sub(时间,INTERVAL 1 MONTH)

yearweek()
返回指定的日期是哪一年的哪个星期,函数形式为 YEARWEEK(date[,mode]) ,其中date的格式一般为‘年-月-日’,mode为1代表一个星期从星期一开始;

weekday()
接受1个参数,即DATE或DATETIME值,函数形式为WEEKDAY(date);返回一个整数,范围从0到6,表示星期一到星期日,即星期一为0,星期二为1,星期日为6;

period_diff()
返回两个时间相差的月份数,注意它是前一个时间减后一个时间。
注意: period1和period2的格式应相同。

?
1
SELECT PERIOD_DIFF(201710, 201703);

按天

查询某一天
根据某天的日期,查询某天的所有时间段数据
例如,2022-11-01查询2022-11-01 00:00:00——2022-11-01 23:59:59的数据
第一种方法(使用DATE_FORMAT)

?
1
2
3
SELECT *
FROM test
WHERE DATE_FORMAT(created_date,'%Y-%m-%d')='2022-11-01';

第二种方法(使用between and)

?
1
2
3
4
5
//使用between and传入开始和结束时间点
//获取的都是11-01的
SELECT *
FROM test
WHERE BETWEEN '2022-11-01' AND '2022-11-02';

第三种方法(使用to_days)

?
1
2
3
SELECT *
FROM test
WHERE to_days(created_date) = to_days('2022-11-01');

第四种方法(使用SUBSTRING)
字符串截取

?
1
2
3
SELECT *
FROM test
WHERE SUBSTRING(created_date,1,10) = '2022-11-01';

昨天

?
1
2
3
SELECT *
FROM test
WHERE TO_DAYS(NOW())-TO_DAYS(created_date)=1;

指定天数

例如,最近x天

?
1
2
3
SELECT *
FROM test
WHERE DATE_SUB(CURDATE(), INTERVAL 2 DAY) <= date(created_date);

按周

当前周数据

?
1
2
3
SELECT *
FROM test
WHERE YEARWEEK(date_format(created_date,‘%Y-%m-%d'))=YEARWEEK(now());

上周的数据

?
1
2
3
SELECT *
FROM test
WHERE YEARWEEK(date_format(created_date,‘%Y-%m-%d'))=YEARWEEK(now())-1;

按月

本月

?
1
2
3
SELECT *
FROM test
WHERE DATE_FORMAT(created_date,'%Y%m') = DATE_FORMAT(CURDATE(),'%Y%m');

上个月

?
1
2
3
SELECT *
FROM test
WHERE PERIOD_DIFF(date_format(now(),'%Y%m'),date_format(时间字段名,'%Y%m'))=1;

距离当前现在x个月

?
1
2
3
4
//例如6个月
SELECT *
FROM test
WHERE submittime BETWEEN DATE_SUB(NOW(),interval 6 month) AND NOW();

按季度

本季度数据

?
1
2
3
SELECT *
FROM test
WHERE QUARTER(created_date)=QUARTER(NOW());

查询上季度数据

?
1
2
3
SELECT *
FROM test
WHERE QUARTER(created_date)=QUARTER(DATE_SUB(NOW(),interval 1 QUARTER));

按年

本年数据

?
1
2
3
SELECT *
FROM test
WHERE YEAR(created_date)=YEAR(NOW());

上年数据

?
1
2
3
SELECT *
FROM test
WHERE YEAR(created_date)=YEAR(DATE_SUB(NOW(),interval 1 year));

到此这篇关于MySql日期查询数据的实现的文章就介绍到这了,更多相关MySql日期查询内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/u011746120/article/details/128385025

延伸 · 阅读

精彩推荐
  • MysqlMySQL嵌套查询实例详解

    MySQL嵌套查询实例详解

    这篇文章主要介绍了MySQL嵌套查询的使用技巧,结合实例形式较为详细的分析了MySQL嵌套查询参数设置、使用方法与注意事项,需要的朋友可以参考下 ...

    MYSQL教程网10352020-05-28
  • Mysqlmysql8.0.11 winx64手动安装配置教程

    mysql8.0.11 winx64手动安装配置教程

    这篇文章主要为大家详细介绍了mysql8.0.11 winx64手动安装配置教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    WangYiFeng_8203706792392020-08-31
  • MysqlMySQL中无GROUP BY情况下直接使用HAVING语句的问题探究

    MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究

    这篇文章主要介绍了MySQL中无GROUP BY情况下直接使用HAVING语句的问题探究,同时探究了该情况下MAX与MIN功能的使用情况,需要的朋友可以参考下 ...

    MYSQL教程网5442020-05-10
  • Mysql简单解析MySQL中的cardinality异常

    简单解析MySQL中的cardinality异常

    这篇文章主要介绍了简单解析MySQL中的cardinality异常,这个异常会导致索引无法使用,需要的朋友可以参考下 ...

    MYSQL教程网5332020-05-05
  • MysqlMySQL OOM(内存溢出)的解决思路

    MySQL OOM(内存溢出)的解决思路

    这篇文章主要介绍了MySQL OOM(内存溢出)的解决思路,文中讲解非常细致,帮助大家在学习工作中解决内存溢出的问题,感兴趣的朋友可以了解下...

    MySQL轻松学11142021-01-24
  • MysqlMySQL 大表的count()优化实现

    MySQL 大表的count()优化实现

    这篇文章主要介绍了MySQL 大表的count()优化实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随...

    阿有耳8482021-05-04
  • Mysqlmysql 5.7.17 winx64.zip安装配置方法图文教程

    mysql 5.7.17 winx64.zip安装配置方法图文教程

    这篇文章主要为大家分享了mysql 5.7.17 winx64.zip安装配置方法图文教程,具有一定的参考价值,感兴趣的朋友可以参考一下...

    fanfan45695122020-07-18
  • Mysql从零开始学习SQL查询语句执行顺序

    从零开始学习SQL查询语句执行顺序

    sql语言中的查询的执行顺序,以前不是很了解,最近查阅了相关资料,在sql语言中,第一个被处理的字句总是from字句,最后执行的limit操作,现在小编来和...

    alwayssmile214072020-09-27