뇨내

[Oracle-SQL Developer] View 본문

Oracle/Join + View + Pseudo

[Oracle-SQL Developer] View

삐옥 2021. 12. 9. 21:01

 

 

 

 

 

 

 

 


 

 

 

 

View 뷰

 

CREATE [OR REPLACE] VIEW 뷰이름 AS SELECT

 

view, 뷰
- DB Object 중 하나(테이블, 시퀀스, 제약사항, 뷰) > CREATE, DROP
- 가상 테이블, 테이블의 복사본, 뷰 테이블 등
-  select문을 저장한 객체

    > 뷰 목적(효과)
    1. 자주 반복되는 쿼리나, 긴 문장의 쿼리를 식별자를 붙여 저장한뒤 간편하게 사용 할 수 있음
    2. 보안 

 

View 사용 시 주의사항

1. SELECT > 실행O 
2. INSERT > 실행O 
3. UPDATE > 실행O
4. DELETE > 실행O 

※SELECT제외하고 전부 사용 금지

 


 

예시

 

 

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
 create or replace view vwEachTeacherLclass
 as
 select 
    distinct t.name as "교사명",
    c.name as "과정명"--
    lc.startclassdate as "개강",
    lc.finishclassdate as "종강",
    cr.name "강의실",
 (select 
    count(distinct(student_seq)) 
from tblteacher t inner join tbllsubject ls on t.teacher_seq = ls.teacher_seq
                  inner join tbllclass lc on lc.lclass_seq = ls.lclass_seq
                  inner join tblsugang su on su.lclass_seq = lc.lclass_seq
    where t.teacher_seq =11) as "등록인원수",
    case
        when lc.startclassdate <= sysdate and lc.finishclassdate >= sysdate then '진행중'
        when lc.startclassdate > sysdate then '예정'
        when lc.startclassdate < sysdate then '종료'
    end as "강의진행상태"
from tblclass c
    inner join tbllclass lc
        on c.class_seq = lc.class_seq
            inner join tbllsubject ls
                on ls.lclass_seq = lc.class_seq
                    inner join tblteacher t
                        on t.teacher_seq = ls.teacher_seq
                            inner join tblclassroom cr
                                on cr.classroom_seq = lc.classroom_seq                                    
                 where ls.teacher_seq = 11
                    order by "개강" asc;
cs

 

 

 

 


 

 

'Oracle > Join + View + Pseudo' 카테고리의 다른 글

[Oracle-SQL Developer] Pseudo Column  (0) 2021.12.11
[Oracle-SQL Developer] JOIN  (0) 2021.12.08
Comments