2014년 5월 29일 목요일

[오라클팁,ORACLE TIP]inline view를 이용한 멀티테이블 삭제(key-reserved)[오라클개발자교육/오라클/ORACLE강좌/오라클교육잘하는곳/오라클교육추천/ORACLE실무교육/ORACLE/ORACLE교육/ORACLE학원/오라클실무교육] DELETE문의 FROM절에 인라인뷰를 이용하여 여러테이블을 기술할 수 있는데 이 경우에는 키보전 테이블(key

[오라클팁,ORACLE TIP]inline view를 이용한 멀티테이블 삭제(key-reserved)[오라클개발자교육/오라클/ORACLE강좌/오라클교육잘하는곳/오라클교육추천/ORACLE실무교육/ORACLE/ORACLE교육/ORACLE학원/오라클실무교육]  

DELETE문의 FROM절에 인라인뷰를 이용하여 여러테이블을 기술할 수 있는데 이 경우에는 키보전 테이블(key reserved table)의 데이터는 삭제되지 않는다. 

아래예제를 통해 이해하자. 

SQL> create table a ( 
  2  seq number, 
  3  name varchar2(20)); 

테이블이 생성되었습니다. 

SQL>  create table b ( 
  2  seq number primary key, 
  3  name varchar2(20)); 

테이블이 생성되었습니다. 

SQL> CREATE SEQUENCE seq_test; 

시퀀스가 생성되었습니다. 

SQL>  INSERT ALL 
  2    INTO a VALUES(seq_test.nextval, name01) 
  3    INTO b VALUES(seq_test.currval,name02) 
  4    SELECT 'aaa' AS name01 , 'bbb' AS name02 
  5    FROM DUAL 
  6  / 

2 개의 행이 만들어졌습니다. 

SQL>  INSERT ALL 
  2    INTO a VALUES(seq_test.nextval, name01) 
  3    INTO b VALUES(seq_test.currval,name02) 
  4    SELECT 'aaa' AS name01 , 'bbb' AS name02 
  5    FROM DUAL 
  6  / 

2 개의 행이 만들어졌습니다. 

SQL> select * from a; 

      SEQ NAME 
---------- -------------------- 
        3 aaa 
        4 aaa 

SQL> select * from b; 

      SEQ NAME 
---------- -------------------- 
        3 bbb 
        4 bbb 


-- 키보전 테이블인 b는 삭제되지 않는다. 

SQL> DELETE FROM 
  2            (SELECT * 
  3              FROM a , b 
  4              WHERE a.seq = b.seq 
  5            ); 

2 행이 삭제되었습니다. 

SQL> select * from a; 

선택된 레코드가 없습니다. 

SQL> select * from b; 

      SEQ NAME 
---------- -------------------- 
        3 bbb 
        4 bbb 



위 예문에서 두 테이블 a, b 둘다 primary key가 없다면 다음과 같은 오류가 발생한다. 

SQL>  DELETE FROM 
  2            (SELECT * 
  3              FROM a , b 
  4              WHERE a.seq = b.seq 
  5            ); 
          (SELECT * 
          * 
2행에 오류: 
ORA-01752: 뷰으로 부터 정확하게 하나의 키-보전된 테이블 없이 삭제할 수 없습니다 

댓글 없음:

댓글 쓰기