LeetCode官方题解
解题思想:
首先按照日期和国家/地区进行分组
对分组后的结果求解,使用IF函数进行过滤
涉及函数
1.在对日期截取时,使用了MySQL中的DATE_FORMAT函数,将日期转换为指定格式的日期
//2024-03-11,截取为 2024-03-11
DATE_FORMAT('2024-03-11','%Y-%m')
//20240311,截取结果为202403
DATE_FORMAT('20240311','%Y%m')
2.该题配合MySQL中的IF函数进行过滤,IF函数中包含了一个三元表达式,当state不等于approved时,将state赋值为NULL或0。
//求取分组后的批准总数
COUNT(IF(state = 'approved', 1, NULL)) AS approved_count
//求取分组后的金额总数
SUM(IF(state = 'approved', amount, 0)) AS approved_total_amount
完整SQL代码:
SELECT DATE_FORMAT(trans_date, '%Y-%m') AS month,
country,
COUNT(*) 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