mysql - 一周中最好的一天

标签 mysql sql group-by sql-order-by

我有一个三列的表格

order;
orderID | ordertotal | datetime

1       | 100.00     | 2015-03-01 17:48:14
2       | 150.00     | 2015-05-10 02:33:20
3       | 5982.23    | 2015-06-11 17:11:30
...

我正在尝试查找一周中几天的 SUMordertotals 的记录。

换句话说,我想看到最好的星期一(订单总和)、最好的星期二和其他。

最后,我将在一周的 7 天中得到如下所示的结果。

 DailyTotal    | DayOfTheWeek | ActualDate

     7500      | Monday       | 2015-03-01
     8000      | Tuesday      | 2015-05-10
     5000      | Wednesday    | 2015-06-11
...

我尝试了这个查询,除了 ActualDate 之外它都有效;

SELECT
    MAX(o2.dailytotal) AS DailyTotal,
    DATE_FORMAT(o2.datetime2, '%W') AS DayOfTheWeek,
    o2.datetime2 AS ActualDate
FROM
    (
        SELECT
            SUM(s1.ordertotal) AS dailytotal,
            DATE(s1.datetime) AS datetime2
        FROM
            order AS o1
        GROUP BY
            DATE(o1.datetime)
    ) AS o2
GROUP BY DATE_FORMAT(o2.datetime2, '%W')
ORDER BY 1 DESC

我在等你的解决方案。

最佳答案

在这种情况下,substring_index()/group_concat() 技巧可能是表达查询的最佳方式:

SELECT MAX(o2.dailytotal) AS DailyTotal,
       DATE_FORMAT(o2.datetime2, '%W') AS DayOfTheWeek,
       SUBSTRING_INDEX(GROUP_CONCAT(o2.datetime2 ORDER BY o2.dailytotal DESC), ',', 1) AS ActualDate
FROM (SELECT DATE(s1.datetime) AS datetime2,
             SUM(s1.ordertotal) AS dailytotal      
      FROM `order` o1
      GROUP BY DATE(o1.datetime)
     ) o2
GROUP BY DATE_FORMAT(o2.datetime2, '%W')
ORDER BY DailyTotal DESC;

这有一些问题(例如将日期转换为字符串以及中间 group_concat() 字符串可能不够大——可以调整)。但是,替代方案会导致更复杂的查询。

您的版本只返回一个不确定的日期。

关于mysql - 一周中最好的一天,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31221141/

相关文章:

python - Pandas 按时间分组,指定开始时间非整数分钟

mysql - @Temporal - 日期格式 - JPA

mysql - 用于 CRM、CMS 和其他金融系统的 RDBMS 与 NoSQL

mysql - 位(8)与tinyint

mysql - 如何计算通过 id 连接的多个表的匹配项数?

mysql - User、User_Group 和 Subscriptions 表之间的高级内部联接

vbscript - 在没有外部工具的情况下从 mysqldump 中排除数据库

sql - Netezza SQL 查询中的字符串运算符

python - 具有值屏蔽的 groupby

python - 使用 groupby 键作为 pandas dataframe 的索引