返回介绍

solution / 1100-1199 / 1193.Monthly Transactions I / README

发布于 2024-06-17 01:03:22 字数 2454 浏览 0 评论 0 收藏 0

1193. 每月交易 I

English Version

题目描述

表:Transactions

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

 

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

任意顺序 返回结果表。

查询结果格式如下所示。

 

示例 1:

输入:
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 |
+------+---------+----------+--------+------------+
输出:
+----------+---------+-------------+----------------+--------------------+-----------------------+
| 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          |
+----------+---------+-------------+----------------+--------------------+-----------------------+

解法

方法一:分组求和

我们可以先按照月份和国家分组,然后利用 COUNTSUM 函数分别求出每个分组的事务数、已批准的事务数、总金额和已批准的总金额。

# Write your MySQL query statement below
SELECT
  DATE_FORMAT(trans_date, '%Y-%m') AS month,
  country,
  COUNT(1) AS trans_count,
  SUM(state = 'approved') AS approved_count,
  SUM(amount) AS trans_total_amount,
  SUM(IF(state = 'approved', amount, 0)) AS approved_total_amount
FROM Transactions
GROUP BY 1, 2;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文