일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 친구랑
- kotlin
- 별5개
- 안드로이드
- 1박2일
- Android
- 개발
- 안드로이드스튜디오
- GitHub
- db
- Java
- Git
- 깃허브
- 코틀린
- 도쿄
- error
- AndroidStudio
- 개발자
- 3박4일
- Eclipse
- 재밌당
- 자바스크립트
- oracle
- 오라클
- 자바
- android studio
- 리눅스
- 오류해결
- JavaScript
- 공부
- Today
- Total
dev_eunz
[DB] 조인의 종류( INNER JOIN, OUTER JOIN, NATURAL JOIN, CROSS JOIN) 본문
DB를 사용하다보면, 다양한 종류의 조인을 접하게 된다.
DB의 조인에는 크게 2가지 조인이 있고,
그 안에 각 2가지씩 해서 4가지가 있다고 보면 된다.
그 중에서 가장 많이 사용하는 조인은 OUTER JOIN 인 것 같다.
일단 크게 나누어보자면,
1. INNER JOIN
2. OUTER JOIN
이렇게 나뉜다.
INNER JOIN의 경우,
A와 B라는 테이블을 JOIN할 때에, 같은 값을 가진 데이터만을 추출해와 새로운 데이터테이블을 뷰로 보여준다.
(데이터의 개수 : 데이터의 교집합 부분)
그 중에 Nature Join 이라는 자연조인은
중복되는 데이터를 없애 데이터의 양이 적다.
(데이터의 개수 : 데이터의 교집합 중, 중복 데이터 제외)
OUTER JOIN의 경우,
A와 B라는 테이블을 JOIN할 때에, 같은 값을 가지고있는 데이터가 아니더라도 왼/오른쪽의 값을 기준으로 데이터를 보여준다.
(데이터의 개수 : 기준이 되는 테이블의 데이터 개수)
Right Join의 경우에는 앞에 선언된 ( SELECT * FROM A RIGHT OUTER JOIN B ~라면, A) 테이블을 기준으로 데이터를 가져오고,
동일 조건에서 Left Join의 경우에는 뒤에 선언된 테이블(B)을 기준으로 가져온다.
그 중에 Cross Join이라는 조인은
양 쪽의 데이터를 모두 겹쳐지게 가져온다.
(데이터의 개수 : 두 개의 테이블의 데이터개수의 곱)
예를 들어서,
A 의 값이 2개, B의 값이 3개라면 가져오는 데이터의 값은 6개가 된다.
A-1 ~ B-1, A-1 ~ B-2, A-1 ~ B-3, A-2 ~ B-1, A-2 ~ B-2, A-2 ~ B-3 이렇게 말이다.
'IT' 카테고리의 다른 글
[헤이조이스] 콘조이스 강연 후기 (0) | 2022.06.01 |
---|---|
[Kotlin] 코틀린 Udemy 인터넷 강의 수강 후기 (0) | 2022.05.21 |
[Mac] Mac OS Eclipse '응용프로그램을 열 수 있는 권한이 없습니다.' (0) | 2022.04.02 |
[Java] sleep 사용해서 일정 시간마다 작동하도록 만들기 (0) | 2022.03.31 |
[Eclipse] Failed to create the java Virtual Machine 실행에러 (0) | 2022.03.30 |