1. Join
join 은 두 테이블의 공통된 정보 (key값)를 기준으로 테이블을 연결해서 한 테이블처럼 보는 것을 의미한다.
여기서 key값이란 똑같은 정보가 담긴 필드를 의미한다.
예를 들어 point_users 테이블과 users 테이블을 연결하려고 할 때,
user_id 라는 공통의 필드를 key값으로 설정해주면 된다.
select * from point_users
left join users
on point_users.user_id = users.user_id
입력 시,
이와 같이 같은 key 값을 가진 것들끼리 연결해준다.
2. Join의 종류
Join에는 Left Join과 Inner Join이 있다.
Left Join은
이 그림을 코드로 표현하면
select * from users u
left join point_users p
on u.user_id = p.user_id
결과는
여기서 [NULL] 이라고 출력된 비어있는 데이터의 경우, 회원이지만 수강을 등록/시작하지 않아 포인트를 획득하지 않은 회원인 경우이다.
Inner Join은
이 그림을 코드로 표현하면
select * from users u
inner join point_users p
on u.user_id = p.user_id
결과는
여기서 [NULL] 인 데이터가 없는 이유는 같은 user_id를 두 테이블에서 모두 가지고 있는 데이터만 출력했기 때문이다.
3. Join 연습
[퀴즈] 결제 수단 별 유저 포인트의 평균값 구해보기 (join 할 테이블 : point_users 에 , orders 붙이기)
select o.payment_method, round(AVG(p.point)) from point_users p
inner join orders o
on p.user_id = o.user_id
group by o.payment_method
[퀴즈] 결제하고 시작하지 않은 유저들을 성씨별로 세어보기 (join 할 테이블 : enrolleds 에, users 를 붙이기)
select name, count(*) as cnt_name from enrolleds e
inner join users u
on e.user_id = u.user_id
where is_registered = 0
group by name
order by cnt_name desc
[퀴즈] 과목 별로 시작하지 않은 유저들을 세어보기 (join 할 테이블 : courses 에, enrolleds 를 붙이기)
select c.course_id, c.title, count(*) as cnt_notstart from courses c
inner join enrolleds e
on c.course_id = e.course_id
where is_registered = 0
group by c.course_id
[퀴즈] 유저 중에, 포인트가 없는 사람의 통계
select name, count(*) from users u
left join point_users pu on u.user_id = pu.user_id
where pu.point_user_id is NULL
group by name
4. 과제
[과제] enrolled_id별 수강완료(done=1)한 강의 갯수를 세어보고, 완료한 강의 수가 많은 순서대로 정렬해보기. user_id도 같이 출력되어야 한다.
select e.enrolled_id,
e.user_id,
count(*) as cnt
from enrolleds e
inner join enrolleds_detail ed on e.enrolled_id = ed.enrolled_id
where ed.done = 1
group by e.enrolled_id, e.user_id
order by cnt desc
이상 끝 ٩( ᐛ )و
'스파르타 코딩클럽 > SQL' 카테고리의 다른 글
[스파르타 코딩 클럽] SQL 4주차 개발일지 (0) | 2021.07.19 |
---|---|
[스파르타 코딩 클럽] SQL 2주차 개발일지 (0) | 2021.06.28 |
[스파르타 코딩 클럽] SQL 1주차 개발일지 (0) | 2021.06.21 |