mysql时间存储如何选择(MySQL如何使用时间作为判断条件)
mysql时间存储如何选择
MySQL如何使用时间作为判断条件背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内......
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')
-- 返回值是11CURDATE()
-- 用法:返回今日的日期,不包括时分秒, 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 |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
原文链接:https://www.cnblogs.com/datangguanjunhou/p/13975035.html
- mysql索引详解及基本用法(Mysql普通索引与唯一索引的选择详析)
- deepin数据库编程(deepin20.1系统安装MySQL8.0.23超详细的MySQL8安装教程)
- mysql慢日志设置多少合适(MySQL慢查询日志的作用和开启)
- linuxmysql怎么设置root密码(Linux mysql-5.6如何实现重置root密码)
- apache2.4支持php5.5吗(WINDOWS下php5.2.4+mysql6.0+apache2.2.4+ZendOptimizer-3.3.0配置)
- mysql顺序排序(Mysql 中文排序规则说明)
- mysql日志功能介绍(mysql日志系统的简单使用教程)
- mysql乐观锁一定比悲观锁性能高(mysql居然还能实现分布式锁的方法)
- docker如何搭建mysql(docker容器访问宿主机的MySQL操作)
- mysql中json的支持(MySQL中json字段的操作方法)
- cent os7.0 安装mysql(mysql8.0.23 linuxcentos7安装完整超详细教程)
- mysql8.0.26安装教程(mysql 8.0.22压缩包完整安装与配置教程图解亲测安装有效)
- mysql8.0配置优化参数(MySQL 8.0 新特性之检查约束的实现)
- navicat连接mysql报1045(解决Navicat for MySQL 连接 MySQL 报2005错误的问题)
- mysql的默认隔离级别(再有人问你MySQL的隔离级别是什么,就把这篇文章发给他!)
- mysql单独导出表(mysql实现从导出数据的sql文件中只导入指定的一个表)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
热门推荐
- vuejs组件使用教程交流(Vue vee-validate插件的简单使用)
- filezilla搭建ftp服务器英文(FileZilla Server FTP服务器安装使用图文教程)
- dedecms标签怎么调用(DEDECMS自定义表单提交后的跳转链接修改方法)
- javascript动作事件有哪些(JavaScript之事件循环案例讲解)
- python图片aes加密(python实现AES加密和解密)
- laravel队列不超时(在laravel中实现事务回滚的方法)
- python单例编程(浅谈Python反射 & 单例模式)
- SQL中AVG、COUNT、SUM、MAX等函数对NULL值处理
- thinkphp标签详解(thinkphp整合系列之极验滑动验证码geetest功能)
- python实现数据的预测(Python基于scipy实现信号滤波功能)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9