美文网首页
Leetcode1193. 每月交易 I(中等)

Leetcode1193. 每月交易 I(中等)

作者: kaka22 | 来源:发表于2020-07-19 10:07 被阅读0次

题目
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                  |
+----------+---------+-------------+----------------+--------------------+-----------------------+

解答
对月份、国家进行分组统计所需变量即可
事务数 count(*)即可
总金额 sum(amount) 即可
已批准的事务数 统计state为approved的数量 及其对应amount

select DATE_FORMAT(t.trans_date, '%Y-%m') AS month, T.country,
count(*) as trans_count,
sum(if(T.state = 'approved', 1, 0)) as approved_count,
sum(T.amount) as trans_total_amount,
sum(if(T.state = 'approved', T.amount, 0)) as approved_total_amount
from Transactions as T
group by month, T.country

一样的

select date_format(trans_date,"%Y-%m") as month,country,
count(id) 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

相关文章

网友评论

      本文标题:Leetcode1193. 每月交易 I(中等)

      本文链接:https://www.haomeiwen.com/subject/orwqkktx.html