在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
背景:在开发过程中,我们经常需要根据时间作为判断条件来查询数据,例如:当月,当日,当前小时,几天内...... 1. 当月 我们只需要使用一个mysql的MONTH(date)函数即可实现。(注意判断年份)
2. 30天内 之所以把“30天内”放在当月的后面,是因为我经常会遇到这两个需求相互转换的情况,“30天内”也可以称作“一个月内”。 这种情况我们需要使用DATEDIFF(expr1,expr2)函数。
3. 当日 当日需要使用TO_DAYS(date)函数。
4. 当前小时 这种情况需要HOUR(date)和CURDATE()函数配合使用。
5. x天内 可以使用DATE_SUB(date,INTERVAL expr unit)函数来实现。
后面的单位unit有很多值可以选择,如下表:
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 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
请发表评论