카테고리 없음

[mysql] 언어별 개발자 분류하기

네카라쭈배 2025. 7. 1. 16:48
728x90

문제 설명

SKILLCODES 테이블은 개발자들이 사용하는 프로그래밍 언어에 대한 정보를 담은 테이블입니다. SKILLCODES 테이블의 구조는 다음과 같으며, NAME, CATEGORY, CODE는 각각 스킬의 이름, 스킬의 범주, 스킬의 코드를 의미합니다. 스킬의 코드는 2진수로 표현했을 때 각 bit로 구분될 수 있도록 2의 제곱수로 구성되어 있습니다.

NAME TYPE UNIQUE NULLABLE

NAME VARCHAR(N) Y N
CATEGORY VARCHAR(N) N N
CODE INTEGER Y N

DEVELOPERS 테이블은 개발자들의 프로그래밍 스킬 정보를 담은 테이블입니다. DEVELOPERS 테이블의 구조는 다음과 같으며, ID, FIRST_NAME, LAST_NAME, EMAIL, SKILL_CODE는 각각 개발자의 ID, 이름, 성, 이메일, 스킬 코드를 의미합니다. SKILL_CODE 컬럼은 INTEGER 타입이고, 2진수로 표현했을 때 각 bit는 SKILLCODES 테이블의 코드를 의미합니다.

NAME TYPE UNIQUE NULLABLE

ID VARCHAR(N) Y N
FIRST_NAME VARCHAR(N) N Y
LAST_NAME VARCHAR(N) N Y
EMAIL VARCHAR(N) Y N
SKILL_CODE INTEGER N N

예를 들어 어떤 개발자의 SKILL_CODE가 400 (=b'110010000')이라면, 이는 SKILLCODES 테이블에서 CODE가 256 (=b'100000000'), 128 (=b'10000000'), 16 (=b'10000') 에 해당하는 스킬을 가졌다는 것을 의미합니다.


문제

DEVELOPERS 테이블에서 GRADE별 개발자의 정보를 조회하려 합니다. GRADE는 다음과 같이 정해집니다.

  • A : Front End 스킬과 Python 스킬을 함께 가지고 있는 개발자
  • B : C# 스킬을 가진 개발자
  • C : 그 외의 Front End 개발자

GRADE가 존재하는 개발자의 GRADE, ID, EMAIL을 조회하는 SQL 문을 작성해 주세요.

결과는 GRADE와 ID를 기준으로 오름차순 정렬해 주세요.


예시

예를 들어 SKILLCODES 테이블이 다음과 같고,

NAME CATEGORY CODE

C++ Back End 4
JavaScript Front End 16
Java Back End 128
Python Back End 256
C# Back End 1024
React Front End 2048
Vue Front End 8192
Node.js Back End 16384

DEVELOPERS 테이블이 다음과 같다면

ID FIRST_NAME LAST_NAME EMAIL SKILL_CODE

D165 Jerami Edwards jerami_edwards@grepp.co 400
D161 Carsen Garza carsen_garza@grepp.co 2048
D164 Kelly Grant kelly_grant@grepp.co 1024
D163 Luka Cory luka_cory@grepp.co 16384
D162 Cade Cunningham cade_cunningham@grepp.co 8452

다음과 같이 DEVELOPERS 테이블에 포함된 개발자들의 GRADE 및 정보가 결과에 나와야 합니다.

GRADE ID EMAIL

A D162 cade_cunningham@grepp.co
A D165 jerami_edwards@grepp.co
B D164 kelly_grant@grepp.co
C D161 carsen_garza@grepp.co

 

 

with skill as 
(
select d.id,d.email,s.name,s.category
from DEVELOPERS d join skillcodes s on d.skill_code & s.code = s.code
),
grade as (
select 
case
    when sum(case when category = 'front end' then 1 else 0 end) > 0 and
    sum(case when name = 'python' then 1 else 0 end) > 0
    then "A"
    when sum(case when name = 'C#' then 1 else 0 end) > 0
    then 'B'
    when sum(case when category = 'front end' then 1 else 0 end) > 0
    then 'C'
    else null
    end as grade,
    id, email 
from skill
group by id, email
)

select *
from grade
where grade is not null
order by grade, id

 

푼 문제 중에서 가장 어려웠던듯 조인자체는 쉬웠는데

테이블이 아닌 "컬럼별"로 "하나라도 값이 있다면" 이라는 조건이 까다로웠음

 

먼저 front end인 개발자의 아이디만 뽑아줌

그리고 grade라는 테이블에서 group by로 id 를 잡아주고

case when 문을 하는데

 

sum(case when category = 'front end' then 1 else 0 end) >0 and sum(case when name = 'python' then 1 else 0 end) > 0 

then 'A' 를 해줘야함

 

이 구문의 뜻은 id별로 그룹을 지었는데 category 중 front end 값 마다 sum 을 해줘서 1개 이상이면 >0 조건에 부합

그리고 마찬가지로 name 중 python 이라는 값을 가진게 있다면  + 1 씩 더 해줌 >0 조건에 부합 하면 "A" 

 

 

 

"이 포스팅은 쿠팡 파트너스 활동의 일환으로, 이에 따른 일정액의 수수료를 제공받습니다."
728x90