背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内......

1. 当月

我们只需要使用一个mysql的month(date)函数即可实现。(注意判断年份)

month(date);

-- 用法:month函数返回一个整数,表示指定日期值的月份。

-- 举例

select month('2020-11-11 00:00:00')

-- 返回值是11

2. 30天内

之所以把“30天内”放在当月的后面,是因为我经常会遇到这两个需求相互转换的情况,“30天内”也可以称作“一个月内”。

这种情况我们需要使用datediff(expr1,expr2)函数。

datediff(expr1,expr2)

-- 用法:参数为两个日期,返回的是expr1-expr2的天数差

-- 举例

select datediff('2020-11-01 08:00:00','2020-11-11 00:00:00')

-- 返回值是-10

3. 当日

当日需要使用to_days(date)函数。

to_days(date)

-- 用法:返回从0000年(公元1年)至当前日期的总天数。

-- 举例

select to_days('0000-01-01')

-- 返回值是1

select to_days('0001-01-01')

-- 返回值是366

4. 当前小时

这种情况需要hour(date)和curdate()函数配合使用。

hour(date)

-- 用法:返回当前时间是今日的第几个小时

-- 举例

select hour('2020-11-11 11:11:11')

-- 返回值是11

curdate()

-- 用法:返回今日的日期,不包括时分秒, yyyy-mm-dd

-- 使用举例

select * from table where created_at > curdate() and hour(created_at) = hour(now())

5. x天内

可以使用date_sub(date,interval expr unit)函数来实现。

date_sub(date,interval expr unit)

-- 用法:起始日期date 减去一个时间段后的日期

后面的单位unit有很多值可以选择,如下表:

类型(unit值)

含义

expr表达式的形式

year

yy

month

mm

day

dd

hour

hh

minute

mm

second

ss

year_month

年和月

yy和mm之间用任意符号隔开

day_hour

日和小时

dd和hh之间用任意符号隔开

day_minute

日和分钟

dd和mm之间用任意符号隔开

day_second

日和秒钟

dd和ss之间用任意符号隔开

hour_minute

时和分

hh和mm之间用任意符号隔开

hour_second

时和秒

hh和ss之间用任意符号隔开

minute_second

分和秒

mm和ss之间用任意符号隔开

-- 举例

-- 七天内的数据查询

select * from table where created_at > date_sub(curdate(),interval 7 day)

6. 多少天内数据统计

我们经常还会遇到这种需求,统计7天内每天数据的量。这种情况下,我们需要考虑没有数据推送的情况,即为0也要得到。

我的思路如下:

select

date_sub( curdate(), interval m.s day ) as orderdate

from

(

select 0 as s union all

select 1 union all

select 2 union all

select 3 union all

select 4 union all

select 5 union all

select 6

) m

以上面的sql查询结果作为临时表,匹配数据表统计多少天内的数据数量

-- 举例:查询12个月内每个月数据的数量

select count(t.created_at),res.date from

(select

date_format(date_sub( curdate(), interval m.s month ),'%y-%m') as date

from

(

select 0 as s union all

select 1 union all

select 2 union all

select 3 union all

select 4 union all

select 5 union all

select 6 union all

select 7 union all

select 8 union all

select 9 union all

select 10 union all

select 11

) m)res

left join

table t on res.date = date_format(t.created_at,'%y-%m')

group by date

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持萬仟网。

希望与广大网友互动??

点此进行留言吧!

mysql日期条件如何应用_MySQL如何使用时间作为判断条件相关推荐

  1. mysql做时间判断_MySQL使用时间作为判断条件

    背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内...... 1. 当月 我们只需要使用一个mysql的MONTH(date)函数即可实现.(注意判断 ...

  2. mysql日期比较大小 方式_mysql中日期比较大小方法详解

    在mysql中日期比较有许多的函数,下面我来给大家总结一下常用的mysql中日期比较大小有需要了解的朋友可进入参考参考,假如有个表product有个字段add_time,它的数据类型为datetime ...

  3. mysql日期sql语句大全_mysql日期查找sql语句大全

    经常会遇到这样的情况,本月阅读排行榜,本周排行榜等等.那么这样的sql怎么写呢,小班收集了一些这样的时间函数给大家参考,希望大家在自己网站项目中可以用的到 在mysql中对时间日期操作的函数有很多,有 ...

  4. mysql 日期能用索引_mysql 日期与索引问题

    日期类型可以直接和string格式的字符串比较 select * from xxx where event_time>'2018-06-02' 可以使用索引, mysql默认会把后面的字符串转成 ...

  5. mysql 日期时间格式化字符串_MySQL日期函数与日期转换格式化函数大全

    Mysql作为一款开元的免费关系型数据库,用户基础非常庞大,本文列出了MYSQL常用日期函数与日期转换格式化函数 1.DAYOFWEEK(date) SELECT DAYOFWEEK('2016-01 ...

  6. mysql日期和时间类型_MySQL日期和时间类型

    MySQL中存储日和和时间,使用日期和时间类型. 提供的包括YEAR.DATE.TIME.DATETIME和TIMESTAMP. YEAR 占用:1字节 取值范围:1901~2155 日期格式:YYY ...

  7. mySQL日期函数并运行_mysql日期相关的函数

    1.获取当前时间: /** 获得当前日期+时间(date + time)函数:now(), 常用 **/ select now() fromdual;/** 获取当前时间戳,current_times ...

  8. mysql日期对应java类型_Mysql与Java日期类型

    java中的日期类型 java.util.Date java.util.Calendar java.sql.Date java.sql.Time java.sql.Timestamp 注:后三种都继承 ...

  9. mysql条件下触发_MySQL的( )可在一定条件下被触发、自动执行一些语句序列。_学小易找答案...

    [填空题]在 Select语句的from子句中,可以使用表或 ( )作为数据源 . [多选题]分娩中可能出现的损伤包括 [填空题]基准一般称为()和(). [单选题]在 select语句的where子 ...

最新文章

  1. DeepStream: 新一代智能城市视频分析
  2. 【知乎热议】没有顶会的CV/NLP方向的博士生毕业出路在哪里?
  3. WPF MvvmLight简单实例(1) 页面导航
  4. ios 处理WKContentView的crash
  5. ViewConfiguration.getScaledTouchSlop () 用法
  6. 五十一、微信小程序云开发中的云函数
  7. 技术分享 | 基于EOS的Dapp开发
  8. *【CodeForces - 1047A】Little C Loves 3 I (水题,构造,三元组问题)
  9. 『飞秋』在.NET 4中调用GDAL库时遇到的问题及解决方法
  10. 基于angular5+ionic3仿照网易云音乐客户端
  11. SAP License:GL显示行项目
  12. cpu相关信息(进程、线程、核...)
  13. 关于图的题目不给数据范围的情况如何解决
  14. Loadrunner教程
  15. 405服务器响应失败,服务器返回HTTP响应代码:405
  16. elisa数据处理过程图解_(完整版)ELISA原理和分类(附图解)
  17. 那个大雨之夜,您与我们同在_____生活中的素质教育
  18. word文档怎么把波浪线去掉_Word实战技巧:干掉波浪线,Word中红色波浪线如何去掉?...
  19. 为了面试能通过,我要看完这75道面试题(下)
  20. 通过mqtt再利用移动oneNet平台的连接与数据收发

热门文章

  1. 技术前沿资讯-Apache Flink 1.14 新特性介绍
  2. python作者 google面试_如果Google面试让你用python写一个树的遍历程序
  3. ssm异常捕获和处理
  4. java else if和switch_如何优雅地优化代码中的的if else和switch
  5. 教你玩转CSS表格(table)
  6. Bash脚本教程之行操作
  7. 开发一个大数据网站做的铺垫
  8. CSRF的绕过与利用
  9. 把html文件变成php,怎么把动态的php文件转换成静态的html文件,html文件是php文件…...
  10. 关于React-native的介绍以及环境搭建