[스파르타 코딩 클럽] SQL 3주차 개발일지

2021. 7. 5. 16:21·스파르타 코딩클럽/SQL
더보기

1. Join

join 은 두 테이블의 공통된 정보 (key값)를 기준으로 테이블을 연결해서 한 테이블처럼 보는 것을 의미한다.

여기서 key값이란 똑같은 정보가 담긴 필드를 의미한다.

 

예를 들어 point_users 테이블과 users 테이블을 연결하려고 할 때,

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
'스파르타 코딩클럽/SQL' 카테고리의 다른 글
  • [스파르타 코딩 클럽] SQL 4주차 개발일지
  • [스파르타 코딩 클럽] SQL 2주차 개발일지
  • [스파르타 코딩 클럽] SQL 1주차 개발일지
오도형석
오도형석
  • 오도형석
    형석이의 성장일기
    오도형석
  • 전체
    오늘
    어제
    • 분류 전체보기 N
      • MSA 모니터링 서비스
        • DB
      • 스파르타 코딩클럽
        • SQL
        • Spring
      • 백엔드
        • Internet
        • Java
        • DB
      • 캡스톤
        • Django
        • 자연어처리
      • Spring
        • JPA
        • MSA
      • ETC
        • ERROR
      • 개발 일기 N
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 인기 글

  • 태그

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
오도형석
[스파르타 코딩 클럽] SQL 3주차 개발일지
상단으로

티스토리툴바