假设某宝为鼓励大家双12买买买,奖励双十一那天订单最多的两位用户:分别是用户1:“剁手皇帝陈哈哈” 和 用户2:“触手怪刘大莉” 一人一万元;
需求1:让你通过MySQL订单表,统计一下双11那天,这两位每小时的购买订单成交数;你会怎么写这条SQL呢?
记得几年前我刚接触MySQl,年少轻狂,在得知不用考虑效率的情况下,我写了个接口循环二十四遍,发送24条SQL去查(捂脸),由于那个接口,被技术经理嘲讽~~表示他写的SQL比我吃的米都多。虽然我们山东人基本不吃米饭,但我还是羞愧不已。。
然后经理通过调用一个DATE_FORMAT函数分组查询处理一下,就ok了,效率是我的几十倍吧。从那时起,我暗自计划要深入研究SQL技巧。
第二天,由于和朋友开黑打了两把王者,计划延后了几年~
在MySQL中对于处理时间字段,有专门封装的DATE_FORMAT函数,可以说,DATE_FORMAT函数可以基本满足任何时间字段的处理需求。
参数解析:
1、date:代表具体时间字段,也可以为now()查询当前时间;
2、format:DATE_FORMAT将传来的Date类型数据转为自己需要的格式,如%Y-%m-%d %H:%i:%s会将传来的Time数据转为"yyyy-MM-dd HH:mm:ss"格式
%Y-%m-%d %H:%i:%s 与 yyyy-MM-dd HH:mm:ss 相对应,也是最常用的格式,这里举几个简单的栗子如下;
SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i:%s'); -- 结果:2020-12-07 22:18:58 SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %H:%i'); -- 结果:2020-12-07 22:18 SELECT DATE_FORMAT(NOW(),'%Y-%m-%d %H'); -- 结果:2020-12-07 22 SELECT DATE_FORMAT(NOW(),'%Y-%m-%d'); -- 结果:2020-12-07 SELECT DATE_FORMAT(NOW(),'%H:%i:%s'); -- 结果:22:18:58 SELECT DATE_FORMAT(NOW(),'%H'); -- 结果:22
对于上面的需求1,用DATE_FORMAT函数的查询方式如下:
SELECT name as '用户名',DATE_FORMAT(createTime,'%Y-%m-%d %H') as '时间/小时',count(*) as '订单量' from t_order where DATE_FORMAT(createTime,'%Y-%m-%d') = '2020-11-11' GROUP BY DATE_FORMAT(createTime,'%Y-%m-%d %H');
查询结果:
mysql> SELECT name as '用户名',DATE_FORMAT(createTime,'%Y-%m-%d %H') as '时间/小时',count(*) as '订单量' from t_order where DATE_FORMAT(createTime,'%Y-%m-%d') = '2020-11-11' GROUP BY DATE_FORMAT(createTime,'%Y-%m-%d %H'); +------------------+---------------+-----------+ | 用户名 | 时间/小时 | 订单量 | +------------------+---------------+-----------+ | 剁手皇帝陈哈哈 | 2020-11-11 00 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 01 | 10 | | 剁手皇帝陈哈哈 | 2020-11-11 02 | 6 | | 剁手皇帝陈哈哈 | 2020-11-11 03 | 3 | | 剁手皇帝陈哈哈 | 2020-11-11 04 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 05 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 06 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 07 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 08 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 09 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 10 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 11 | 0 | | 剁手皇帝陈哈哈 | 2020-11-11 12 | 12 | | 剁手皇帝陈哈哈 | 2020-11-11 13 | 6 | | 剁手皇帝陈哈哈 | 2020-11-11 14 | 3 | | 剁手皇帝陈哈哈 | 2020-11-11 15 | 7 | | 剁手皇帝陈哈哈 | 2020-11-11 16 | 2 | | 剁手皇帝陈哈哈 | 2020-11-11 17 | 3 | | 剁手皇帝陈哈哈 | 2020-11-11 18 | 11 | | 剁手皇帝陈哈哈 | 2020-11-11 19 | 2 | | 剁手皇帝陈哈哈 | 2020-11-11 20 | 1 | | 剁手皇帝陈哈哈 | 2020-11-11 21 | 3 | | 剁手皇帝陈哈哈 | 2020-11-11 22 | 2 | | 剁手皇帝陈哈哈 | 2020-11-11 23 | 0 | +------------------+---------------+-----------+ 24 rows in set (0.00 sec)
这里的GROUP BY DATE_FORMAT(createTime,'%Y-%m-%d %H')代表的是“年月日 + 小时”合在一起为单位,具体到的是某天的小时;
当然,也可以写成以下两种形式,都是按小时来划分,但是…:
1、GROUP BY DATE_FORMAT(createTime,'%H')
2、GROUP BY HOUR(createTime)
需要注意的是,当where条件指定了某一天时,这三种的作用是相同的,但如果where条件没指定某一天,就会大不相同,我们来看看查询结果;
SELECT name as '用户名',DATE_FORMAT(createTime,'%H') as '时间/小时',count(*) as '订单量' from t_order GROUP BY DATE_FORMAT(createTime,'%H');
查询结果
mysql> SELECT name as '用户名',DATE_FORMAT(createTime,'%H') as '时间/小时',count(*) as '订单量' from t_order GROUP BY DATE_FORMAT(createTime,'%H'); +-----------------+---------------+-----------+ | 用户名 | 时间/小时 | 订单量 | +-----------------+---------------+-----------+ | 触手怪刘大莉 | 00 | 11 | | 触手怪刘大莉 | 01 | 302 | | 触手怪刘大莉 | 02 | 277 | | 触手怪刘大莉 | 03 | 122 | | 触手怪刘大莉 | 04 | 6 | | 触手怪刘大莉 | 05 | 11 | | 触手怪刘大莉 | 06 | 0 | | 触手怪刘大莉 | 07 | 0 | | 触手怪刘大莉 | 08 | 1 | | 触手怪刘大莉 | 09 | 4 | | 触手怪刘大莉 | 10 | 5 | | 触手怪刘大莉 | 11 | 92 | | 触手怪刘大莉 | 12 | 1937 | | 触手怪刘大莉 | 13 | 1602 | | 触手怪刘大莉 | 14 | 108 | | 触手怪刘大莉 | 15 | 78 | | 触手怪刘大莉 | 16 | 110 | | 触手怪刘大莉 | 17 | 108 | | 触手怪刘大莉 | 18 | 138 | | 触手怪刘大莉 | 19 | 66 | | 触手怪刘大莉 | 20 | 44 | | 触手怪刘大莉 | 21 | 59 | | 触手怪刘大莉 | 22 | 21 | | 触手怪刘大莉 | 23 | 8 | +-----------------+---------------+-----------+ 24 rows in set (0.01 sec)
通过查询结果可以看出,查出的数据是用户历史所有的订单数在各小时的分布情况,DATE_FORMAT(createTime,'%H')代表的是是任意天的小时,也等价于GROUP BY HOUR(createTime)。
拿到这些数据,相信写推荐算法的同学就知道在哪个时间段给“触手怪刘大莉”同学推广告的效果最好了。
到此这篇关于MySQL的DATE_FORMAT函数的使用的文章就介绍到这了,更多相关MySQL DATE_FORMAT内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
问题内容: 我用谷歌搜索并尝试了几种比较日期的方法,但不幸的是没有得到预期的结果。我有如下记录的当前状态: 我想比较日期,因此这样做: 我认为结果不应包含“ 28-10-2012”。有什么建议吗?提前致谢。 问题答案: 您的格式根本不是什么排序一个开始-你是比较 字符串 ,字符串“28-10-2012” 是 不是“2012年2月11日”更大。 相反,您应该将日期 作为date 进行比较,然后仅将其
本文向大家介绍MySql用DATE_FORMAT截取DateTime字段的日期值,包括了MySql用DATE_FORMAT截取DateTime字段的日期值的使用技巧和注意事项,需要的朋友参考一下 用 DATE_FORMAT 来格式化日期字段
本文向大家介绍在MySQL中使用DATE_FORMAT()和STR_TO_DATE()格式化日期,包括了在MySQL中使用DATE_FORMAT()和STR_TO_DATE()格式化日期的使用技巧和注意事项,需要的朋友参考一下 让我们首先创建一个表- 使用插入命令在表中插入一些记录- 使用select语句显示表中的所有记录- 这将产生以下输出- 以下是格式化日期的查询- 让我们使用select语句
为什么下面的MySQL代码不能工作--特别是dense_rank()函数,因为“employee_number”总是以两个字母开头,例如。“AB61026”、'AB64238'等。
问题内容: 我想这样做,以便在MySQL查询中对NOW()和CURDATE()的调用以UTC返回日期。如何在不检查和更改所有使用这些功能的查询的情况下实现这一目标? 问题答案: 终于找到了我想要的… 在my.cnf中, 我将此选项放在[mysqld]下,而mysql无法启动。 呼叫“ SET time_zone =’+ 0:00’;” 在每个页面加载上也可以工作,但是我不喜欢在每个页面加载上调用该
问题内容: 假设有一个日期框架,其中的一列包含日期作为字符串。为此,我们创建以下dataFrame作为示例: 在上面的代码中,将生成一个随机日期列,下面是一个示例: 我正在尝试使用以下代码(来自pySpark文档)更改日期格式: 但是我得到这个不好的结果: 我想有一个与字符串dataType有关的问题,但与此同时,我不明白为什么下面的代码行得通,而上面的代码却行不通。 输出: 这是我想要的最后结果
本文向大家介绍mysql中find_in_set函数的基本使用方法,包括了mysql中find_in_set函数的基本使用方法的使用技巧和注意事项,需要的朋友参考一下 前言 这是我最近新接触到的一个函数, 我在项目中的使用场景是这样的: 有一个应用类型表,表中有parentId字段和parentIds字段,前者为父级id,后者为多级父级id,在库中都是varchar类型,parentIds由多个父
问题内容: 我正在使用MySQL。这是我的架构: 供应商( sid:整数 ,sname:字符串,地址字符串) 零件( pid:整数 ,pname:字符串,color:字符串) 目录( sid:整数,pid:整数 ,成本:实数) (主键以粗体显示) 我正在尝试编写查询以选择至少两个供应商制造的所有零件: 首先,我什至会以正确的方式这样做吗? 其次,我得到这个错误: 1111-无效使用组功能 我究竟做