[Oracle] 인라인뷰
(정의) 인라인뷰: SQL문장에서 FROM 절에 사용된 서브쿼리
데이터베이스 객체인 뷰와 비슷하나, 인라인 뷰는 서브쿼리라는 특성 때문에 하나의 SQL 문장에서만 사용가능하며 데이터베이스 객체가 아니다. 임시성 뷰라고 생각할 수 있다.
인라인 뷰의 필요성(예제)
select a.employee_id, a.first_name||' '||a.last_name, a.salary
from employees a
where a.salary >= (select avg(salary) from employees)
and a.salary <= (select max(salary) from employees)
order by a.salary desc;
--> 만약 평균 급여, 최대 급여까지 함께 보여 주고 싶다면?
select a.employee_id, a.first_name||' '||a.last_name names, a.salary, round(b.avgs), b.maxs
from employees a, (select avg(salary) avgs, max(salary) maxs from employees) b
where a.salary between b.avgs and b.maxs
order by a.salary desc;
* from 절에 2개의 table이 명시되었으나, Join 구문이 포함되지 않았으므로 양 테이블의 catenation 곱으로 표현되었다. (총 레코드 개수(51) = a레코드 개수(51) * b레코드 개수(1))
인라인 뷰의 필요성(예제2)
월별 입사 현황 구하기
*레코드 개수 12개 결과 만들기
select
decode(to_char(hire_date,'mm'), '01', count(*), 0) "1월",
decode(to_char(hire_date,'mm'), '02', count(*), 0) "2월",
decode(to_char(hire_date,'mm'), '03', count(*), 0) "3월",
decode(to_char(hire_date,'mm'), '04', count(*), 0) "4월",
decode(to_char(hire_date,'mm'), '05', count(*), 0) "5월",
decode(to_char(hire_date,'mm'), '06', count(*), 0) "6월",
decode(to_char(hire_date,'mm'), '07', count(*), 0) "7월",
decode(to_char(hire_date,'mm'), '08', count(*), 0) "8월",
decode(to_char(hire_date,'mm'), '09', count(*), 0) "9월",
decode(to_char(hire_date,'mm'), '10', count(*), 0) "10월",
decode(to_char(hire_date,'mm'), '11', count(*), 0) "11월",
decode(to_char(hire_date,'mm'), '12', count(*), 0) "12월"
from employees
group by to_char(hire_date,'mm')
order by to_char(hire_date,'mm');
*레코드 개수 1개 결과 만들기
select sum(m1) "1월", sum(m2) "2월", sum(m3) "3월", sum(m4) "4월", sum(m5) "5월", sum(m6) "6월", sum(m7) "7월", sum(m8) "8월", sum(m9) "9월", sum(m10) "10월", sum(m11) "11월", sum(m12) "12월"
from (
select decode(to_char(hire_date,'mm'), '01', count(*), 0) m1,
decode(to_char(hire_date,'mm'), '02', count(*), 0) m2,
decode(to_char(hire_date,'mm'), '03', count(*), 0) m3,
decode(to_char(hire_date,'mm'), '04', count(*), 0) m4,
decode(to_char(hire_date,'mm'), '05', count(*), 0) m5,
decode(to_char(hire_date,'mm'), '06', count(*), 0) m6,
decode(to_char(hire_date,'mm'), '07', count(*), 0) m7,
decode(to_char(hire_date,'mm'), '08', count(*), 0) m8,
decode(to_char(hire_date,'mm'), '09', count(*), 0) m9,
decode(to_char(hire_date,'mm'), '10', count(*), 0) m10,
decode(to_char(hire_date,'mm'), '11', count(*), 0) m11,
decode(to_char(hire_date,'mm'), '12', count(*), 0) m12
from employees
group by to_char(hire_date,'mm')
);
인라인 뷰의 필요성(예제3)
select *
from (
select employee_id, first_name, last_name, salary
from employees
order by salary desc
)
where rownum <= 10;
*뇌를 자극하는 오라클 프로그래밍(홍형경 저) 참조함
'Oracle_DB_Unix admin > (3)뇌자극 오라클 PL/SQL' 카테고리의 다른 글
PL/SQL 문장과 커서 (0) | 2015.10.08 |
---|---|
PL/SQL 객체 (0) | 2015.10.04 |
[Oracle] 서브쿼리의 분류 (0) | 2015.10.03 |
[Oracle] 연관성 있는 서브쿼리와 연관성 있는 서브쿼리 (0) | 2015.10.03 |
[Oracle] EXISTS 연산자의 활용 (0) | 2015.10.03 |