LeetCode-1193. 每月交易 I(中等)DATE_FORMAT COUNT sum(加条件)

Table: Transactions

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| id            | int     |
| country       | varchar |
| state         | enum    |
| amount        | int     |
| trans_date    | date    |
+---------------+---------+
id 是这个表的主键。
该表包含有关传入事务的信息。
state 列类型为 “[”批准“,”拒绝“] 之一。
 

编写一个 sql 查询来查找每个月和每个国家/地区的事务数及其总金额、已批准的事务数及其总金额。

查询结果格式如下所示:

Transactions table:
+------+---------+----------+--------+------------+
| id   | country | state    | amount | trans_date |
+------+---------+----------+--------+------------+
| 121  | US      | approved | 1000   | 2018-12-18 |
| 122  | US      | declined | 2000   | 2018-12-19 |
| 123  | US      | approved | 2000   | 2019-01-01 |
| 124  | DE      | approved | 2000   | 2019-01-07 |
+------+---------+----------+--------+------------+

Result table:
+----------+---------+-------------+----------------+--------------------+-----------------------+
| month    | country | trans_count | approved_count | trans_total_amount | approved_total_amount |
+----------+---------+-------------+----------------+--------------------+-----------------------+
| 2018-12  | US      | 2           | 1              | 3000               | 1000                  |
| 2019-01  | US      | 1           | 1              | 2000               | 2000                  |
| 2019-01  | DE      | 1           | 1              | 2000               | 2000                  |
+----------+---------+-------------+----------------+--------------------+-----------------------+

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/monthly-transactions-i
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

审题:编写一个 sql 查询来查找每个月和每个国家/地区的事务数及其总金额、已批准的事务数及其总金额。

每个月、每个国家,事物和总额,已经批复的总额。

思考:先按照日期和国家分组,然后求数量,以及总金额之类的数字。

解题:

关键点有两个:
1.使用DATE_FORMAT()函数把日期转换成月份
2.count()/sum()函数在聚合时加入条件
(sum()函数中返回0/count()函数中返回null可以过滤掉不符合记录)

--  Write your MySQL query statement below

SELECT DATE_FORMAT(trans_date, '%Y-%m') AS month, country
	, COUNT(1) AS trans_count
	, COUNT(if(state = 'approved', 1, NULL)) AS approved_count
	, SUM(amount) AS trans_total_amount
	, SUM(if(state = 'approved', amount, 0)) AS approved_total_amount
FROM Transactions
GROUP BY month, country

知识点:

DATE_FORMAT

COUNT

sum

DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据。

发布了144 篇原创文章 · 获赞 2 · 访问量 5749

猜你喜欢

转载自blog.csdn.net/Hello_JavaScript/article/details/104650265