Post

퀘스트 - 걷기반 6) 팀 프로젝트 열심히 했으니 다시 놀아볼까요?!

퀘스트 - 걷기반 6) 팀 프로젝트 열심히 했으니 다시 놀아볼까요?!

문제

아래와 같은 lol_users(LOL 유저 테이블)이 있습니다.

idnameregionratingjoin_date
1르탄이한국13002019-06-15
2배캠이미국15002020-09-01
3구구이한국14002021-01-07
4이션이미국13502019-11-15

21. lol_users테이블에서 각 유저의 레이팅(rating) 순위를 계산하는 쿼리를 작성해주세요!
전체 지역(region) 기준이고 순위는 레이팅이 높을수록 높아야해요. (e.g. rating 1400 유저의 순위 > rating 1350 유저의 순위)
22. lol_users테이블에서 가장 늦게 게임을 시작한(join_date) 유저의 이름을 선택하는 쿼리를 작성해주세요!
23. lol_users테이블에서 지역별로 레이팅이 높은 순으로 유저들을 정렬해서 나열하는 쿼리를 작성해주세요!
24. lol_users테이블에서 지역별로 평균 레이팅을 계산하는 쿼리를 작성해주세요!




문제 풀이

21. lol_users테이블에서 각 유저의 레이팅(rating) 순위를 계산하는 쿼리를 작성해주세요!
전체 지역(region) 기준이고 순위는 레이팅이 높을수록 높아야해요. (e.g. rating 1400 유저의 순위 > rating 1350 유저의 순위)

1
2
3
4
5
6
7
select id,
       name,
       region,
       rating,
       join_date,
       rank() over (order by rating desc) lol_rank
from lol_users;


22. lol_users테이블에서 가장 늦게 게임을 시작한(join_date) 유저의 이름을 선택하는 쿼리를 작성해주세요!

1
2
3
4
select name
from lol_users
order by join_date desc
limit 1;
  • LIMIT을 통해 정해진 숫자만큼의 데이터만 추출할 수 있습니다


23. lol_users테이블에서 지역별로 레이팅이 높은 순으로 유저들을 정렬해서 나열하는 쿼리를 작성해주세요!

1
2
3
select *
from lol_users
order by region, reating desc;


24. lol_users테이블에서 지역별로 평균 레이팅을 계산하는 쿼리를 작성해주세요!

1
2
3
4
select regison,
       avg(rating) avg_rating
from lol_users
group by region;
This post is licensed under CC BY 4.0 by the author.