首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在SQL中对具有不同日期值的行进行分组和排序

如何在SQL中对具有不同日期值的行进行分组和排序
EN

Stack Overflow用户
提问于 2020-06-11 18:15:56
回答 1查看 32关注 0票数 1

我有这样的结果:

代码语言:javascript
复制
+---------------------------+-----------+------------+
|           Date            | InvoiceID |  Amount    |
+---------------------------+-----------+------------+
| 2020-06-09 12:36:37.433   | AF-1      | 189,876996 |
| 2020-06-09 12:36:37.483   | AF-1      | 59,4       |
| 2020-06-09 12:36:37.490   | AF-1      | 15,8544    |
| 2020-06-09 12:37:42.790   | AF-2      | 20,2       |
| 2020-06-09 12:39:29.453   | AF-4      | 70,6596    |
| 2020-06-09 12:43:30.553   | SF-1      | 47,1064    |
| 2020-06-09 12:43:30.577   | SF-1      | 12,96      |
| 2020-06-09 12:43:30.583   | SF-1      | 17,3664    |
| 2020-06-09 12:44:51.963   | SF-3      | 34,3905    |
| 2020-06-09 12:49:34.147   | TM-1      | 500        |
| 2020-06-09 12:50:26.040   | TM-2      | 150        |
| 2020-06-09 12:50:26.063   | TM-2      | 600        |
| 2020-06-09 12:51:29.817   | GH-1      | 500        |
| 2020-06-09 12:51:29.823   | GH-1      | 313,68     |
+---------------------------+-----------+------------+

查询非常简单:

代码语言:javascript
复制
Select Date, InvoiceID, Amount from TableName order by Date

我需要把它们分组,按日期得到数量和订单的总和。请注意,日期值并不相同。因为这个我不能分组结果。重要的是我需要按日期列订购。这就是我想要的结果:

代码语言:javascript
复制
+-----------+-------------+
| InvoiceID |   Amount    |
+-----------+-------------+
| AF-1      | 265,131396  |
| AF-2      | 20,2        |
| AF-4      | 70,6596     |
| SF-1      | 77,4328     |
| SF-3      | 34,3905     |
| TM-1      | 500         |
| TM-2      | 750         |
| GH-1      | 813,68      |
+-----------+-------------+

我正在尝试这段代码,但是sql给了我一个错误,我需要在group子句中使用Date列。

代码语言:javascript
复制
SELECT InvoiceID, sum(Amount) as Amount from TableName group by InvoiceID order by Date

我对SQL非常陌生,有人能建议我如何解决这个问题吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-11 18:17:40

您需要聚合,但也需要一个用于排序的聚合函数:

代码语言:javascript
复制
SELECT InvoiceID, sum(Amount) as Amount 
FROM TableName 
GROUP BY InvoiceID 
ORDER BY MIN(Date);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62330900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档