DBMS-조인

우리는 함께 쌍을 이루는 가능한 모든 튜플을 제공하는 두 관계의 데카르트 곱을 취하는 이점을 이해합니다. 그러나 어떤 경우에는 상당한 수의 속성을 가진 수천 개의 튜플과 거대한 관계가있는 데카르트 곱을 취하는 것이 불가능할 수도 있습니다.

Join데카르트 곱과 선택 프로세스의 조합입니다. Join 연산은 주어진 조인 조건이 충족되는 경우에만 서로 다른 관계에서 두 개의 튜플을 쌍으로 만듭니다.

다음 섹션에서는 다양한 조인 유형에 대해 간략하게 설명합니다.

세타 (θ) 조인

Theta 조인은 theta 조건을 충족하는 경우 다른 관계의 튜플을 결합합니다. 결합 조건은 기호로 표시됩니다.θ.

표기법

R1 ⋈θ R2

R1과 R2는 속성 (A1, A2, .., An)과 (B1, B2, .., Bn) 속성이 공통점이없는 관계, 즉 R1 ∩ R2 = Φ입니다.

세타 조인은 모든 종류의 비교 연산자를 사용할 수 있습니다.

학생
SID 이름 Std
101 알렉스 10
102 마리아 11
과목
수업 제목
10 수학
10 영어
11 음악
11 스포츠

Student_Detail −

STUDENT Student.Std = Subject.Class SUBJECT

Student_detail
SID 이름 Std 수업 제목
101 알렉스 10 10 수학
101 알렉스 10 10 영어
102 마리아 11 11 음악
102 마리아 11 11 스포츠

Equijoin

Theta 조인 만 사용하는 경우 equality비교 연산자는 동등 조인이라고합니다. 위의 예는 equijoin에 해당합니다.

자연 결합 ( )

자연 조인은 비교 연산자를 사용하지 않습니다. 데카르트 곱이하는 방식을 연결하지 않습니다. 두 관계 사이에 하나 이상의 공통 속성이있는 경우에만 자연 조인을 수행 할 수 있습니다. 또한 속성은 동일한 이름과 도메인을 가져야합니다.

자연 조인은 두 관계의 속성 값이 동일한 일치 속성에 대해 작동합니다.

과정
CID 강좌 부서
CS01 데이터 베이스 CS
ME01 역학 나를
EE01 전자 EE
벽돌 상자
부서 머리
CS 알렉스
나를 마야
EE 미라
코스 ⋈ HoD
부서 CID 강좌 머리
CS CS01 데이터 베이스 알렉스
나를 ME01 역학 마야
EE EE01 전자 미라

외부 결합

Theta Join, Equijoin 및 Natural Join을 내부 조인이라고합니다. 내부 조인에는 속성이 일치하는 튜플 만 포함되고 나머지는 결과 관계에서 삭제됩니다. 따라서 결과 관계에 참여 관계의 모든 튜플을 포함하려면 외부 조인을 사용해야합니다. 외부 조인에는 왼쪽 외부 조인, 오른쪽 외부 조인 및 완전 외부 조인의 세 가지 종류가 있습니다.

왼쪽 외부 결합 (RS
)

Left 관계 R의 모든 튜플이 결과 관계에 포함됩니다. 오른쪽 관계 S에 일치하는 튜플이없는 튜플이 R에있는 경우 결과 관계의 S- 속성은 NULL이됩니다.

왼쪽
100 데이터 베이스
101 역학
102 전자
권리
100 알렉스
102 마야
104 미라
코스
HoD
100 데이터 베이스 100 알렉스
101 역학 --- ---
102 전자 102 마야

오른쪽 외부 결합 : (
RS)

오른쪽 관계 S의 모든 튜플이 결과 관계에 포함됩니다. R에 일치하는 튜플이없는 튜플이 S에있는 경우 결과 관계의 R 속성은 NULL이됩니다.

코스
HoD
100 데이터 베이스 100 알렉스
102 전자 102 마야
--- --- 104 미라

전체 외부 결합 : (
RS)

참여하는 두 관계의 모든 튜플이 결과 관계에 포함됩니다. 두 관계 모두에 대해 일치하는 튜플이 없으면 각각의 일치하지 않는 속성이 NULL이됩니다.

코스
HoD
100 데이터 베이스 100 알렉스
101 역학 --- ---
102 전자 102 마야
--- --- 104 미라