2014년 5월 28일 수요일

[오라클팁,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: 뷰으로 부터 정확하게 하나의 키-보전된 테이블 없이 삭제할 수 없습니다 [출처] 오라클자바커뮤니티 - http://www.oraclejavacommunity.co.kr/bbs/board.php?bo_table=oracleTip&wr_id=733 오라클자바커뮤니티교육센터, 개발자전문교육, 개인80%환급 www.oraclejavacommunity.com 평일주간(9:30~18:20) 개강 (5/30)[기업100%환급]자바기초에서 JDBC, Servlet/JSP까지 (5/30)[기업100%환급]SQL기초에서 Schema Object까지 (6/09)[기업100%환급]PL/SQL,ORACLE HINT,TUNING (6/09)[기업100%환급]안드로이드개발자과정 (6/09)[기업100%환급]Spring ,MyBatis,Hibernate실무과정 (6/16)[기업100%환급]C#4.0,WinForm,ADO.NET프로그래밍 (6/23)[교육전취업확정,채용예정자교육]Spring,MyBatis,XPlatform실무프로젝트과정 평일야간(19:00~21:50) 개강 (5/29)자바기초에서JSP,Ajax,jQuery,Spring3.2,MyBatis까지 (6/03)안드로이드개발자과정 (6/03)웹퍼블리싱 마스터 (6/10)C#4.0, ADO.NET, Network 프로그래밍 (6/10)Spring3.X, MyBatis, Hibernate실무과정 (6/18)C#,ASP.NET마스터 (6/26)SQL초보에서실전전문가까지 주말(10:00~17:50) 개강 (5/31)Spring3.X, MyBatis, Hibernate실무과정 (5/31)자바기초에서JSP,Ajax,jQuery,Spring3.2,MyBatis까지 (5/31)SQL초보에서실전전문가까지 (5/31)C#,ASP.NET마스터 (5/31)실무예제로 배워보는 jQuery(개발자/디자이너를위한) (5/31)안드로이드개발자과정 주말저녁(18:30~22:20) 개강 (6/21)JAVA,Network&WEB&Framework (6/21)SQL기초에서실무까지

[오라클팁,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: 뷰으로 부터 정확하게 하나의 키-보전된 테이블 없이 삭제할 수 없습니다 

댓글 없음:

댓글 쓰기