Skip to content

Commit d5897fb

Browse files
committed
[level 4] Title: 오프라인/온라인 판매 데이터 통합하기, Time: 0.00 ms, Memory: 0.0 MB -BaekjoonHub
1 parent a876a87 commit d5897fb

File tree

2 files changed

+280
-0
lines changed

2 files changed

+280
-0
lines changed
Lines changed: 263 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,263 @@
1+
# [level 4] 오프라인/온라인 판매 데이터 통합하기 - 131537
2+
3+
[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/131537)
4+
5+
### 성능 요약
6+
7+
메모리: 0.0 MB, 시간: 0.00 ms
8+
9+
### 구분
10+
11+
코딩테스트 연습 > SELECT
12+
13+
### 채점결과
14+
15+
Empty
16+
17+
### 제출 일자
18+
19+
2025년 11월 04일 10:44:03
20+
21+
### 문제 설명
22+
23+
<p>다음은 어느 의류 쇼핑몰의 온라인 상품 판매 정보를 담은 <code>ONLINE_SALE</code> 테이블과 오프라인 상품 판매 정보를 담은 <code>OFFLINE_SALE</code> 테이블 입니다. <code>ONLINE_SALE</code> 테이블은 아래와 같은 구조로 되어있으며 <code>ONLINE_SALE_ID</code>, <code>USER_ID</code>, <code>PRODUCT_ID</code>, <code>SALES_AMOUNT</code>, <code>SALES_DATE</code>는 각각 온라인 상품 판매 ID, 회원 ID, 상품 ID, 판매량, 판매일을 나타냅니다.</p>
24+
<table class="table">
25+
<thead><tr>
26+
<th>Column name</th>
27+
<th>Type</th>
28+
<th>Nullable</th>
29+
</tr>
30+
</thead>
31+
<tbody><tr>
32+
<td>ONLINE_SALE_ID</td>
33+
<td>INTEGER</td>
34+
<td>FALSE</td>
35+
</tr>
36+
<tr>
37+
<td>USER_ID</td>
38+
<td>INTEGER</td>
39+
<td>FALSE</td>
40+
</tr>
41+
<tr>
42+
<td>PRODUCT_ID</td>
43+
<td>INTEGER</td>
44+
<td>FALSE</td>
45+
</tr>
46+
<tr>
47+
<td>SALES_AMOUNT</td>
48+
<td>INTEGER</td>
49+
<td>FALSE</td>
50+
</tr>
51+
<tr>
52+
<td>SALES_DATE</td>
53+
<td>DATE</td>
54+
<td>FALSE</td>
55+
</tr>
56+
</tbody>
57+
</table>
58+
<p>동일한 날짜, 회원 ID, 상품 ID 조합에 대해서는 하나의 판매 데이터만 존재합니다.</p>
59+
60+
<p><code>OFFLINE_SALE</code> 테이블은 아래와 같은 구조로 되어있으며 <code>OFFLINE_SALE_ID</code>, <code>PRODUCT_ID</code>, <code>SALES_AMOUNT</code>, <code>SALES_DATE</code>는 각각 오프라인 상품 판매 ID, 상품 ID, 판매량, 판매일을 나타냅니다.</p>
61+
<table class="table">
62+
<thead><tr>
63+
<th>Column name</th>
64+
<th>Type</th>
65+
<th>Nullable</th>
66+
</tr>
67+
</thead>
68+
<tbody><tr>
69+
<td>OFFLINE_SALE_ID</td>
70+
<td>INTEGER</td>
71+
<td>FALSE</td>
72+
</tr>
73+
<tr>
74+
<td>PRODUCT_ID</td>
75+
<td>INTEGER</td>
76+
<td>FALSE</td>
77+
</tr>
78+
<tr>
79+
<td>SALES_AMOUNT</td>
80+
<td>INTEGER</td>
81+
<td>FALSE</td>
82+
</tr>
83+
<tr>
84+
<td>SALES_DATE</td>
85+
<td>DATE</td>
86+
<td>FALSE</td>
87+
</tr>
88+
</tbody>
89+
</table>
90+
<p>동일한 날짜, 상품 ID 조합에 대해서는 하나의 판매 데이터만 존재합니다.</p>
91+
92+
<hr>
93+
94+
<h5>문제</h5>
95+
96+
<p><code>ONLINE_SALE</code> 테이블과 <code>OFFLINE_SALE</code> 테이블에서 2022년 3월의 오프라인/온라인 상품 판매 데이터의 판매 날짜, 상품ID, 유저ID, 판매량을 출력하는 SQL문을 작성해주세요. <code>OFFLINE_SALE</code> 테이블의 판매 데이터의 <code>USER_ID</code> 값은 NULL 로 표시해주세요. 결과는 판매일을 기준으로 오름차순 정렬해주시고 판매일이 같다면 상품 ID를 기준으로 오름차순, 상품ID까지 같다면 유저 ID를 기준으로 오름차순 정렬해주세요.</p>
97+
98+
<hr>
99+
100+
<h5>예시</h5>
101+
102+
<p>예를 들어 <code>ONLINE_SALE</code> 테이블이 다음과 같고</p>
103+
<table class="table">
104+
<thead><tr>
105+
<th>ONLINE_SALE_ID</th>
106+
<th>USER_ID</th>
107+
<th>PRODUCT_ID</th>
108+
<th>SALES_AMOUNT</th>
109+
<th>SALES_DATE</th>
110+
</tr>
111+
</thead>
112+
<tbody><tr>
113+
<td>1</td>
114+
<td>1</td>
115+
<td>3</td>
116+
<td>2</td>
117+
<td>2022-02-25</td>
118+
</tr>
119+
<tr>
120+
<td>2</td>
121+
<td>4</td>
122+
<td>4</td>
123+
<td>1</td>
124+
<td>2022-03-01</td>
125+
</tr>
126+
<tr>
127+
<td>4</td>
128+
<td>2</td>
129+
<td>2</td>
130+
<td>2</td>
131+
<td>2022-03-02</td>
132+
</tr>
133+
<tr>
134+
<td>3</td>
135+
<td>6</td>
136+
<td>3</td>
137+
<td>3</td>
138+
<td>2022-03-02</td>
139+
</tr>
140+
<tr>
141+
<td>5</td>
142+
<td>5</td>
143+
<td>5</td>
144+
<td>1</td>
145+
<td>2022-03-03</td>
146+
</tr>
147+
<tr>
148+
<td>6</td>
149+
<td>5</td>
150+
<td>7</td>
151+
<td>1</td>
152+
<td>2022-04-06</td>
153+
</tr>
154+
</tbody>
155+
</table>
156+
<p><code>OFFLINE_SALE</code> 테이블이 다음과 같다면</p>
157+
<table class="table">
158+
<thead><tr>
159+
<th>OFFLINE_SALE_ID</th>
160+
<th>PRODUCT_ID</th>
161+
<th>SALES_AMOUNT</th>
162+
<th>SALES_DATE</th>
163+
</tr>
164+
</thead>
165+
<tbody><tr>
166+
<td>1</td>
167+
<td>1</td>
168+
<td>2</td>
169+
<td>2022-02-21</td>
170+
</tr>
171+
<tr>
172+
<td>4</td>
173+
<td>1</td>
174+
<td>2</td>
175+
<td>2022-03-01</td>
176+
</tr>
177+
<tr>
178+
<td>3</td>
179+
<td>3</td>
180+
<td>3</td>
181+
<td>2022-03-01</td>
182+
</tr>
183+
<tr>
184+
<td>2</td>
185+
<td>4</td>
186+
<td>1</td>
187+
<td>2022-03-01</td>
188+
</tr>
189+
<tr>
190+
<td>5</td>
191+
<td>2</td>
192+
<td>1</td>
193+
<td>2022-03-03</td>
194+
</tr>
195+
<tr>
196+
<td>6</td>
197+
<td>2</td>
198+
<td>1</td>
199+
<td>2022-04-01</td>
200+
</tr>
201+
</tbody>
202+
</table>
203+
<p>각 테이블의 2022년 3월의 판매 데이터를 합쳐서, 정렬한 결과는 다음과 같아야 합니다.</p>
204+
<table class="table">
205+
<thead><tr>
206+
<th>SALES_DATE</th>
207+
<th>PRODUCT_ID</th>
208+
<th>USER_ID</th>
209+
<th>SALES_AMOUNT</th>
210+
</tr>
211+
</thead>
212+
<tbody><tr>
213+
<td>2022-03-01</td>
214+
<td>1</td>
215+
<td>NULL</td>
216+
<td>2</td>
217+
</tr>
218+
<tr>
219+
<td>2022-03-01</td>
220+
<td>3</td>
221+
<td>NULL</td>
222+
<td>3</td>
223+
</tr>
224+
<tr>
225+
<td>2022-03-01</td>
226+
<td>4</td>
227+
<td>NULL</td>
228+
<td>1</td>
229+
</tr>
230+
<tr>
231+
<td>2022-03-01</td>
232+
<td>4</td>
233+
<td>4</td>
234+
<td>1</td>
235+
</tr>
236+
<tr>
237+
<td>2022-03-02</td>
238+
<td>2</td>
239+
<td>2</td>
240+
<td>2</td>
241+
</tr>
242+
<tr>
243+
<td>2022-03-02</td>
244+
<td>3</td>
245+
<td>6</td>
246+
<td>3</td>
247+
</tr>
248+
<tr>
249+
<td>2022-03-03</td>
250+
<td>2</td>
251+
<td>NULL</td>
252+
<td>1</td>
253+
</tr>
254+
<tr>
255+
<td>2022-03-03</td>
256+
<td>5</td>
257+
<td>5</td>
258+
<td>1</td>
259+
</tr>
260+
</tbody>
261+
</table>
262+
263+
> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
-- 코드를 입력하세요
2+
SELECT
3+
DATE_FORMAT(SALES_DATE, '%Y-%m-%d') AS SALES_DATE,
4+
PRODUCT_ID,
5+
USER_ID,
6+
SALES_AMOUNT
7+
FROM ONLINE_SALE
8+
WHERE SALES_DATE like '2022-03%'
9+
UNION
10+
SELECT
11+
DATE_FORMAT(SALES_DATE, '%Y-%m-%d') AS SALES_DATE,
12+
PRODUCT_ID,
13+
NULL AS USER_ID,
14+
SALES_AMOUNT
15+
FROM OFFLINE_SALE
16+
WHERE SALES_DATE like '2022-03%'
17+
ORDER BY SALES_DATE, PRODUCT_ID, USER_ID;

0 commit comments

Comments
 (0)