[오라클팁,ORACLE TIP]inline view를 이용한 멀티테이블 삭제(key-reserved)
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: 뷰으로 부터 정확하게 하나의 키-보전된 테이블 없이 삭제할 수 없습니다
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: 뷰으로 부터 정확하게 하나의 키-보전된 테이블 없이 삭제할 수 없습니다
기업100%환급/오라클/자바/스프링/안드로이드/닷넷C#/웹퍼블리싱… | 12-27 | 2285 | ||
[채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취… | 12-11 | 1638 | ||
53 | [평일주간100%환급]Spring,JAVA,JSP,안드로이드,C#닷넷,SQL,튜닝… | 03-15 | 1450 | |
52 | [주말]C#,ASP.NET마스터 | 01-31 | 1562 | |
51 | [기업100%환급,평일주간]SQL기초에서스키마오브젝트,PLSQL,힌트… | 01-31 | 1879 | |
50 | [기업100%환급]개발자를위한스프링,마이바티스,하이버네이트(스… | 01-31 | 1236 | |
49 | [평일주간,평일야간,주말]Spring,MyBatis,Hibernate개발자과정 | 01-19 | 1538 | |
48 | [평일주간,평일야간,주말]안드로이드개발자과정 | 01-11 | 1366 | |
47 | [평일야간,주말주간,주말야간]JAVA,Network&JSP&Spring,MyBatis,… | 01-03 | 1903 | |
46 | 기업100%환급/오라클/자바/스프링/안드로이드/닷넷C#/웹퍼블리싱… | 12-27 | 2285 | |
45 | [기업100%환급]자바웹개발기초과정(JAVA,JDBC,JSP,Servlet,Aajx,… | 12-19 | 1641 | |
44 | [평일주간야간, 주말]웹퍼블리싱 마스터(HTML5,CSS3,jQUERY,AJAX… | 12-14 | 1605 | |
43 | [채용예정교육]오라클자바개발잘하는신입뽑기2개월과정,교육전취… | 12-11 | 1638 | |
42 | [주말주간]자바&웹,jQUERY,스프링프레임워크 | 12-09 | 1310 | |
41 | [평일야간]닷넷(C#,Network,ADO.NET,ASP.NET)마스터 | 12-01 | 1538 | |
40 | [기업100%환급]자바기초&안드로이드개발자과정(Android전액환급… | 12-01 | 1723 | |
39 | [평일야간,주말]SQL기초에서실무까지(SQL기초,PLSQL,힌트,튜닝) | 12-01 | 1183 |
댓글 없음:
댓글 쓰기