鱼C论坛

 找回密码
 立即注册
查看: 1487|回复: 0

MYSQL错题整理(1205. 每月交易II)

[复制链接]
发表于 2020-4-4 22:06:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
题目描述:
  1. Transactions 记录表

  2. +----------------+---------+
  3. | Column Name    | Type    |
  4. +----------------+---------+
  5. | id             | int     |
  6. | country        | varchar |
  7. | state          | enum    |
  8. | amount         | int     |
  9. | trans_date     | date    |
  10. +----------------+---------+
  11. id 是这个表的主键。
  12. 该表包含有关传入事务的信息。
  13. 状态列是类型为 [approved(已批准)、declined(已拒绝)] 的枚举。
  14.  

  15. Chargebacks 表

  16. +----------------+---------+
  17. | Column Name    | Type    |
  18. +----------------+---------+
  19. | trans_id       | int     |
  20. | charge_date    | date    |
  21. +----------------+---------+
  22. 退单包含有关放置在事务表中的某些事务的传入退单的基本信息。
  23. trans_id 是 transactions 表的 id 列的外键。
  24. 每项退单都对应于之前进行的交易,即使未经批准。
  25.  

  26. 编写一个 SQL 查询,以查找每个月和每个国家/地区的已批准交易的数量及其总金额、退单的数量及其总金额。

  27. 注意:在您的查询中,给定月份和国家,忽略所有为零的行。

  28. 查询结果格式如下所示:

  29. Transactions 表:
  30. +------+---------+----------+--------+------------+
  31. | id   | country | state    | amount | trans_date |
  32. +------+---------+----------+--------+------------+
  33. | 101  | US      | approved | 1000   | 2019-05-18 |
  34. | 102  | US      | declined | 2000   | 2019-05-19 |
  35. | 103  | US      | approved | 3000   | 2019-06-10 |
  36. | 104  | US      | approved | 4000   | 2019-06-13 |
  37. | 105  | US      | approved | 5000   | 2019-06-15 |
  38. +------+---------+----------+--------+------------+

  39. Chargebacks 表:
  40. +------------+------------+
  41. | trans_id   | trans_date |
  42. +------------+------------+
  43. | 102        | 2019-05-29 |
  44. | 101        | 2019-06-30 |
  45. | 105        | 2019-09-18 |
  46. +------------+------------+

  47. Result 表:
  48. +----------+---------+----------------+-----------------+-------------------+--------------------+
  49. | month    | country | approved_count | approved_amount | chargeback_count  | chargeback_amount  |
  50. +----------+---------+----------------+-----------------+-------------------+--------------------+
  51. | 2019-05  | US      | 1              | 1000            | 1                 | 2000               |
  52. | 2019-06  | US      | 3              | 12000           | 1                 | 1000               |
  53. | 2019-09  | US      | 0              | 0               | 1                 | 5000               |
  54. +----------+---------+----------------+-----------------+-------------------+--------------------+

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



  1. SELECT
  2. month,country,
  3. SUM(CASE WHEN state='approved' THEN 1 ELSE 0 END)approved_count,
  4. SUM(CASE WHEN state='approved' THEN amount ELSE 0 END)approved_amount,
  5. SUM(CASE WHEN state='refund' THEN 1 ELSE 0 END)chargeback_count,
  6. SUM(CASE WHEN state='refund' THEN amount ELSE 0 END)chargeback_amount
  7. FROM
  8. (SELECT DATE_FORMAT(trans_date,'%Y-%m')month,country,state,amount,id
  9. FROM Transactions
  10. UNION ALL
  11. SELECT DATE_FORMAT(c.trans_date,'%Y-%m')month,country,'refund' AS state,amount,trans_id
  12. FROM
  13. Chargebacks c LEFT JOIN Transactions t ON c.trans_id=t.id) data
  14. GROUP BY month,country
  15. HAVING approved_count+chargeback_count>0
复制代码




注意事项:
1.MYSQL中的全连接。

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-26 18:07

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表