本文主要是介绍LeetCode刷题---每月交易I,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
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
这篇关于LeetCode刷题---每月交易I的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!