Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- GROUP BY
- static메서드
- 다중 모달창
- 스프링 모달창
- 템플릿
- oracle 연동
- order by
- Java
- 싱클톤패턴
- 이클립스 오라클 연동
- 상속
- static
- 형변환
- singleton
- 사용자 데이터그램 프로토콜
- 객체협력
- 추상 메서드
- IP
- 깃 명령어
- spring annotation
- SUB Query
- 모달창 여러개
- 다운캐스팅
- AOP란?
- 오라클 비교연산자
- react
- Servlet 맵핑
- 리스트 모달창
- static 예제
- downcasting
Archives
- Today
- Total
모든지 기록하자!
[Oracle] JOIN 과 예시 본문
728x90
/*
JOIN
두개 이상의 테이블을 연결해서 데이터를 검색하는 방법
보통 두개 이상의 행(ROW)들의 공통된 값 기본키, 왜래키를 사용해서 JOIN한다.
목적 : 현재에서 상대 테이블의 정보(column) 산출하기 위한 것
기본키(Primary key) : 테이블에서 중복되지 않는 키
외래키(Foreign key) : 다른 테이블에서 기본키 이거나 고유키인 경우가 많다.
JOIN 종류
inner join = 교집합 *****
full outer join = 합집합
cross join
outer join ***
left
right
self join *****
*/
-- inner join
-- ansi SQL
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e INNER JOIN departments d
ON e.department_id = d.department_id;
-- oracle
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id;
-- JOB_ID == IT_PROG 업무명
SELECT e.employee_id, e.first_name,
e.job_id, j.job_id,
j.job_title
FROM employees e, jobs j
WHERE e.job_id = j.job_id
AND e.job_id = 'IT_PROG';
-- 3개 테이블 조인
SELECT e.employee_id, e.first_name,
d.department_name, j.job_title
FROM employees e, departments d, jobs j
WHERE e.department_id = d.department_id
AND e.job_id = j.job_id
AND e.employee_id = 101;
-- cross join
-- ansi
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e CROSS JOIN departments d;
-- oracle
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d;
-- full outer join
-- ansi
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e FULL OUTER JOIN departments d
ON e.department_id = d.department_id;
-- oracle
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id(+) -- +위치에 따라 바뀜 지금은 left join
UNION
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id(+) = d.department_id; -- +위치에 따라 바뀜 지금은 right join
-- left outer
-- ansi
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e LEFT OUTER JOIN departments d -- LEFT를 RIGHT로 바꿀수 있음
ON e.department_id = d.department_id;
-- oracle
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id(+); -- (+)기호가 없는 쪽으로 조인된다. (없는쪽이 중심이 된다.)
-- left 차집합
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id = d.department_id(+)
AND e.department_id IS NULL;
-- right 차집합
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id(+) = d.department_id
AND e.department_id IS NULL;
SELECT e.employee_id, e.first_name,
e.department_id, d.department_id,
d.department_name
FROM employees e, departments d
WHERE e.department_id(+) = d.department_id
AND e.department_id IS NOT NULL;
728x90
'Database' 카테고리의 다른 글
[Oracle] ORDER BY , GROUP BY 예제 (0) | 2021.05.28 |
---|---|
[Oracle] hr 표준함수 예제 (0) | 2021.05.28 |
[Oracle] SELECT문, WHERE절, 비교연산자 기초 예제 (0) | 2021.05.26 |
[Oracle] ORDER BY , GROUP BY 와 예제 (0) | 2021.05.26 |
[Oracle] WHERE절과 비교연산자와 예제 (0) | 2021.05.26 |
Comments