반응형
목차
문제
Table: DailySales
+-------------+---------+
| Column Name | Type |
+-------------+---------+
| date_id | date |
| make_name | varchar |
| lead_id | int |
| partner_id | int |
+-------------+---------+
This table does not have a primary key.
This table contains the date and the name of the product sold and the IDs of the lead and partner it was sold to.
The name consists of only lowercase English letters.
Write an SQL query that will, for each date_id and make_name, return the number of distinct lead_id's and distinct partner_id's.
Return the result table in any order.
The query result format is in the following example.
Example 1:
Input:
DailySales table:
+-----------+-----------+---------+------------+
| date_id | make_name | lead_id | partner_id |
+-----------+-----------+---------+------------+
| 2020-12-8 | toyota | 0 | 1 |
| 2020-12-8 | toyota | 1 | 0 |
| 2020-12-8 | toyota | 1 | 2 |
| 2020-12-7 | toyota | 0 | 2 |
| 2020-12-7 | toyota | 0 | 1 |
| 2020-12-8 | honda | 1 | 2 |
| 2020-12-8 | honda | 2 | 1 |
| 2020-12-7 | honda | 0 | 1 |
| 2020-12-7 | honda | 1 | 2 |
| 2020-12-7 | honda | 2 | 1 |
+-----------+-----------+---------+------------+
Output:
+-----------+-----------+--------------+-----------------+
| date_id | make_name | unique_leads | unique_partners |
+-----------+-----------+--------------+-----------------+
| 2020-12-8 | toyota | 2 | 3 |
| 2020-12-7 | toyota | 1 | 2 |
| 2020-12-8 | honda | 2 | 2 |
| 2020-12-7 | honda | 3 | 2 |
+-----------+-----------+--------------+-----------------+
Explanation:
For 2020-12-8, toyota gets leads = [0, 1] and partners = [0, 1, 2] while honda gets leads = [1, 2] and partners = [1, 2].
For 2020-12-7, toyota gets leads = [0] and partners = [1, 2] while honda gets leads = [0, 1, 2] and partners = [1, 2].
풀이
# Write your MySQL query statement below
select
date_id
,make_name
,count(distinct lead_id) as unique_leads
,count(distinct partner_id) as unique_partners
from DailySales
group by date_id, make_name
/* Write your PL/SQL query statement below */
select
to_char(date_id, 'YYYY-MM-DD') as date_id
,make_name
,count(distinct lead_id) as unique_leads
,count(distinct partner_id) as unique_partners
from DailySales
group by date_id, make_name
반응형
'코딩테스트 > SQL 문제풀이' 카테고리의 다른 글
[MySQL/Oracle] 627. Swap Salary (0) | 2022.11.11 |
---|---|
[MySQL/Oracle] 1873. Calculate Special Bonus (0) | 2022.11.11 |
[MySQL/Oracle] 1741. Find Total Time Spent by Each Employee (0) | 2022.11.08 |
[MySQL] 중복 제거하기 (0) | 2022.11.08 |
[MySQL] 동물 수 구하기 (0) | 2022.11.08 |
댓글