-
Notifications
You must be signed in to change notification settings - Fork 118
/
1205_Monthly_Transactions_II.sql
32 lines (31 loc) · 1.21 KB
/
1205_Monthly_Transactions_II.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
-- Solution: Subquery, Join
-- find the number of approved transactions and their total amount for each month and country
WITH tb1 AS (
SELECT LEFT(trans_date,7) AS month, country,
COUNT(state) AS approved_count,
SUM(amount) AS approved_amount
FROM Transactions
WHERE state = 'approved'
GROUP BY LEFT(trans_date,7), country
),
-- find the number of chargebacks and their total amount for each month and country
tb2 AS (
SELECT LEFT(c.trans_date,7) AS month, country,
COUNT(c.trans_id) AS chargeback_count,
SUM(t.amount) AS chargeback_amount
FROM Chargebacks c
JOIN Transactions t
ON c.trans_id = t.id
GROUP BY LEFT(c.trans_date,7), country
)
-- when there is no approved transactions or chargebacks for a country in a certain month,
-- replace the NULL with 0
SELECT COALESCE(tb1.month,tb2.month) AS month,
COALESCE(tb1.country,tb2.country) AS country,
ISNULL(tb1.approved_count,0) AS approved_count,
ISNULL(tb1.approved_amount,0) AS approved_amount,
ISNULL(tb2.chargeback_count,0) AS chargeback_count,
ISNULL(tb2.chargeback_amount,0) AS chargeback_amount
FROM tb1
FULL OUTER JOIN tb2
ON tb1.month = tb2.month AND tb1.country = tb2.country;