Skip to content

Commit f8621bc

Browse files
committed
[level 4] Title: 연간 평가점수에 해당하는 평가 등급 및 성과금 조회하기, Time: , Memory: undefined -BaekjoonHub
1 parent f0a9847 commit f8621bc

File tree

2 files changed

+402
-0
lines changed

2 files changed

+402
-0
lines changed
Lines changed: 381 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,381 @@
1+
# [level 4] 연간 평가점수에 해당하는 평가 등급 및 성과금 조회하기 - 284528
2+
3+
[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/284528)
4+
5+
### 성능 요약
6+
7+
메모리: undefined, 시간:
8+
9+
### 구분
10+
11+
코딩테스트 연습 > GROUP BY
12+
13+
### 채점결과
14+
15+
합계: 100.0 / 100.0
16+
17+
### 제출 일자
18+
19+
2025년 11월 10일 14:56:22
20+
21+
### 문제 설명
22+
23+
<p><code>HR_DEPARTMENT</code> 테이블은 회사의 부서 정보를 담은 테이블입니다. <code>HR_DEPARTMENT</code> 테이블의 구조는 다음과 같으며 <code>DEPT_ID</code>, <code>DEPT_NAME_KR</code>, <code>DEPT_NAME_EN</code>, <code>LOCATION</code>은 각각 부서 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>DEPT_ID</td>
33+
<td>VARCHAR</td>
34+
<td>FALSE</td>
35+
</tr>
36+
<tr>
37+
<td>DEPT_NAME_KR</td>
38+
<td>VARCHAR</td>
39+
<td>FALSE</td>
40+
</tr>
41+
<tr>
42+
<td>DEPT_NAME_EN</td>
43+
<td>VARCHAR</td>
44+
<td>FALSE</td>
45+
</tr>
46+
<tr>
47+
<td>LOCATION</td>
48+
<td>VARCHAR</td>
49+
<td>FLASE</td>
50+
</tr>
51+
</tbody>
52+
</table>
53+
<p><code>HR_EMPLOYEES</code> 테이블은 회사의 사원 정보를 담은 테이블입니다. <code>HR_EMPLOYEES</code> 테이블의 구조는 다음과 같으며 <code>EMP_NO</code>, <code>EMP_NAME</code>, <code>DEPT_ID</code>, <code>POSITION</code>, <code>EMAIL</code>, <code>COMP_TEL</code>, <code>HIRE_DATE</code>, <code>SAL</code>은 각각 사번, 성명, 부서 ID, 직책, 이메일, 전화번호, 입사일, 연봉을 의미합니다.</p>
54+
<table class="table">
55+
<thead><tr>
56+
<th>Column name</th>
57+
<th>Type</th>
58+
<th>Nullable</th>
59+
</tr>
60+
</thead>
61+
<tbody><tr>
62+
<td>EMP_NO</td>
63+
<td>VARCHAR</td>
64+
<td>FALSE</td>
65+
</tr>
66+
<tr>
67+
<td>EMP_NAME</td>
68+
<td>VARCHAR</td>
69+
<td>FALSE</td>
70+
</tr>
71+
<tr>
72+
<td>DEPT_ID</td>
73+
<td>VARCHAR</td>
74+
<td>FALSE</td>
75+
</tr>
76+
<tr>
77+
<td>POSITION</td>
78+
<td>VARCHAR</td>
79+
<td>FALSE</td>
80+
</tr>
81+
<tr>
82+
<td>EMAIL</td>
83+
<td>VARCHAR</td>
84+
<td>FALSE</td>
85+
</tr>
86+
<tr>
87+
<td>COMP_TEL</td>
88+
<td>VARCHAR</td>
89+
<td>FALSE</td>
90+
</tr>
91+
<tr>
92+
<td>HIRE_DATE</td>
93+
<td>DATE</td>
94+
<td>FALSE</td>
95+
</tr>
96+
<tr>
97+
<td>SAL</td>
98+
<td>NUMBER</td>
99+
<td>FALSE</td>
100+
</tr>
101+
</tbody>
102+
</table>
103+
<p><code>HR_GRADE</code> 테이블은 2022년 사원의 평가 정보를 담은 테이블입니다. <code>HR_GRADE</code>의 구조는 다음과 같으며 <code>EMP_NO</code>, <code>YEAR</code>, <code>HALF_YEAR</code>, <code>SCORE</code>는 각각 사번, 연도, 반기, 평가 점수를 의미합니다.</p>
104+
<table class="table">
105+
<thead><tr>
106+
<th>Column name</th>
107+
<th>Type</th>
108+
<th>Nullable</th>
109+
</tr>
110+
</thead>
111+
<tbody><tr>
112+
<td>EMP_NO</td>
113+
<td>VARCHAR</td>
114+
<td>FALSE</td>
115+
</tr>
116+
<tr>
117+
<td>YEAR</td>
118+
<td>NUMBER</td>
119+
<td>FALSE</td>
120+
</tr>
121+
<tr>
122+
<td>HALF_YEAR</td>
123+
<td>NUMBER</td>
124+
<td>FALSE</td>
125+
</tr>
126+
<tr>
127+
<td>SCORE</td>
128+
<td>NUMBER</td>
129+
<td>FALSE</td>
130+
</tr>
131+
</tbody>
132+
</table>
133+
<hr>
134+
135+
<h5>문제</h5>
136+
137+
<p><code>HR_DEPARTMENT</code>, <code>HR_EMPLOYEES</code>, <code>HR_GRADE</code> 테이블을 이용해 사원별 성과금 정보를 조회하려합니다. 평가 점수별 등급과 등급에 따른 성과금 정보가 아래와 같을 때, 사번, 성명, 평가 등급, 성과금을 조회하는 SQL문을 작성해주세요.</p>
138+
139+
<p>평가등급의 컬럼명은 <code>GRADE</code>로, 성과금의 컬럼명은 <code>BONUS</code>로 해주세요.<br>
140+
결과는 사번 기준으로 오름차순 정렬해주세요.</p>
141+
<table class="table">
142+
<thead><tr>
143+
<th>기준 점수</th>
144+
<th>평가 등급</th>
145+
<th>성과금(연봉 기준)</th>
146+
</tr>
147+
</thead>
148+
<tbody><tr>
149+
<td>96 이상</td>
150+
<td>S</td>
151+
<td>20%</td>
152+
</tr>
153+
<tr>
154+
<td>90 이상</td>
155+
<td>A</td>
156+
<td>15%</td>
157+
</tr>
158+
<tr>
159+
<td>80 이상</td>
160+
<td>B</td>
161+
<td>10%</td>
162+
</tr>
163+
<tr>
164+
<td>이외</td>
165+
<td>C</td>
166+
<td>0%</td>
167+
</tr>
168+
</tbody>
169+
</table>
170+
<hr>
171+
172+
<h5>예시</h5>
173+
174+
<p><code>HR_DEPARTMENT</code> 테이블이 다음과 같고</p>
175+
<table class="table">
176+
<thead><tr>
177+
<th>DEPT_ID</th>
178+
<th>DEPT_NAME_KR</th>
179+
<th>DEPT_NAME_EN</th>
180+
<th>LOCATION</th>
181+
</tr>
182+
</thead>
183+
<tbody><tr>
184+
<td>D0001</td>
185+
<td>법무팀</td>
186+
<td>Law Dep</td>
187+
<td>그렙타워 4층</td>
188+
</tr>
189+
<tr>
190+
<td>D0002</td>
191+
<td>인사팀</td>
192+
<td>Human resources</td>
193+
<td>그렙타워 4층</td>
194+
</tr>
195+
<tr>
196+
<td>D0003</td>
197+
<td>총무팀</td>
198+
<td>General Affairs</td>
199+
<td>그렙타워 4층</td>
200+
</tr>
201+
</tbody>
202+
</table>
203+
<p><code>HR_EMPLOYEES</code> 테이블이 다음과 같고</p>
204+
<table class="table">
205+
<thead><tr>
206+
<th>EMP_NO</th>
207+
<th>EMP_NAME</th>
208+
<th>DEPT_ID</th>
209+
<th>POSITION</th>
210+
<th>EMAIL</th>
211+
<th>COMP_TEL</th>
212+
<th>HIRE_DATE</th>
213+
<th>SAL</th>
214+
</tr>
215+
</thead>
216+
<tbody><tr>
217+
<td>2017002</td>
218+
<td>정호식</td>
219+
<td>D0001</td>
220+
<td>팀장</td>
221+
<td><a href="mailto:hosick_jung@grep.com" target="_blank" rel="noopener">hosick_jung@grep.com</a></td>
222+
<td>031-8000-1101</td>
223+
<td>2017-03-01</td>
224+
<td>65000000</td>
225+
</tr>
226+
<tr>
227+
<td>2018001</td>
228+
<td>김민석</td>
229+
<td>D0001</td>
230+
<td>팀원</td>
231+
<td><a href="mailto:minseock_kim@grep.com" target="_blank" rel="noopener">minseock_kim@grep.com</a></td>
232+
<td>031-8000-1102</td>
233+
<td>2018-03-01</td>
234+
<td>60000000</td>
235+
</tr>
236+
<tr>
237+
<td>2019001</td>
238+
<td>김솜이</td>
239+
<td>D0002</td>
240+
<td>팀장</td>
241+
<td><a href="mailto:somi_kim@grep.com" target="_blank" rel="noopener">somi_kim@grep.com</a></td>
242+
<td>031-8000-1106</td>
243+
<td>2019-03-01</td>
244+
<td>60000000</td>
245+
</tr>
246+
<tr>
247+
<td>2020002</td>
248+
<td>김연주</td>
249+
<td>D0002</td>
250+
<td>팀원</td>
251+
<td><a href="mailto:yeonjoo_kim@grep.com" target="_blank" rel="noopener">yeonjoo_kim@grep.com</a></td>
252+
<td>031-8000-1107</td>
253+
<td>2020-03-01</td>
254+
<td>53000000</td>
255+
</tr>
256+
<tr>
257+
<td>2020005</td>
258+
<td>양성태</td>
259+
<td>D0003</td>
260+
<td>팀원</td>
261+
<td><a href="mailto:sungtae_yang@grep.com" target="_blank" rel="noopener">sungtae_yang@grep.com</a></td>
262+
<td>031-8000-1112</td>
263+
<td>2020-03-01</td>
264+
<td>53000000</td>
265+
</tr>
266+
</tbody>
267+
</table>
268+
<p><code>HR_GRADE</code> 테이블이 다음과 같을 때</p>
269+
<table class="table">
270+
<thead><tr>
271+
<th>EMP_NO</th>
272+
<th>YEAR</th>
273+
<th>HALF_YEAR</th>
274+
<th>SCORE</th>
275+
</tr>
276+
</thead>
277+
<tbody><tr>
278+
<td>2017002</td>
279+
<td>2022</td>
280+
<td>1</td>
281+
<td>92</td>
282+
</tr>
283+
<tr>
284+
<td>2018001</td>
285+
<td>2022</td>
286+
<td>1</td>
287+
<td>89</td>
288+
</tr>
289+
<tr>
290+
<td>2019001</td>
291+
<td>2022</td>
292+
<td>1</td>
293+
<td>94</td>
294+
</tr>
295+
<tr>
296+
<td>2020002</td>
297+
<td>2022</td>
298+
<td>1</td>
299+
<td>90</td>
300+
</tr>
301+
<tr>
302+
<td>2020005</td>
303+
<td>2022</td>
304+
<td>1</td>
305+
<td>92</td>
306+
</tr>
307+
<tr>
308+
<td>2017002</td>
309+
<td>2022</td>
310+
<td>2</td>
311+
<td>84</td>
312+
</tr>
313+
<tr>
314+
<td>2018001</td>
315+
<td>2022</td>
316+
<td>2</td>
317+
<td>89</td>
318+
</tr>
319+
<tr>
320+
<td>2019001</td>
321+
<td>2022</td>
322+
<td>2</td>
323+
<td>81</td>
324+
</tr>
325+
<tr>
326+
<td>2020002</td>
327+
<td>2022</td>
328+
<td>2</td>
329+
<td>91</td>
330+
</tr>
331+
<tr>
332+
<td>2020005</td>
333+
<td>2022</td>
334+
<td>2</td>
335+
<td>81</td>
336+
</tr>
337+
</tbody>
338+
</table>
339+
<p>다음과 같이 사원별 성과금 정보를 출력해야 합니다.</p>
340+
<table class="table">
341+
<thead><tr>
342+
<th>EMP_NO</th>
343+
<th>EMP_NAME</th>
344+
<th>GRADE</th>
345+
<th>BONUS</th>
346+
</tr>
347+
</thead>
348+
<tbody><tr>
349+
<td>2017002</td>
350+
<td>정호식</td>
351+
<td>B</td>
352+
<td>6500000</td>
353+
</tr>
354+
<tr>
355+
<td>2018001</td>
356+
<td>김민석</td>
357+
<td>B</td>
358+
<td>6000000</td>
359+
</tr>
360+
<tr>
361+
<td>2019001</td>
362+
<td>김솜이</td>
363+
<td>B</td>
364+
<td>6000000</td>
365+
</tr>
366+
<tr>
367+
<td>2020002</td>
368+
<td>김연주</td>
369+
<td>A</td>
370+
<td>7950000</td>
371+
</tr>
372+
<tr>
373+
<td>2020005</td>
374+
<td>양성태</td>
375+
<td>B</td>
376+
<td>5300000</td>
377+
</tr>
378+
</tbody>
379+
</table>
380+
381+
> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges

0 commit comments

Comments
 (0)