두 개의 SELECT 명령에 대한 검색결과를 이용하여 집합 결과값을 제공하는 연산자
--SUPER_HERO 테이블 생성 - 속성 : 이름(문자형)
CREATE TABLE SUPER_HERO(NAME VARCHAR2(20) PRIMARY KEY);
--SUPER_HERO 테이블에 행 삽입
INSERT INTO SUPER_HERO VALUES('슈퍼맨');
INSERT INTO SUPER_HERO VALUES('아이언맨');
INSERT INTO SUPER_HERO VALUES('배트맨');
INSERT INTO SUPER_HERO VALUES('앤트맨');
INSERT INTO SUPER_HERO VALUES('스파이더맨');
SELECT * FROM SUPER_HERO;
COMMIT;
--MARVEL_HERO 테이블 생성 - 속성 : 이름(문자형),등급(숫자형)
CREATE TABLE MARVEL_HERO(NAME VARCHAR2(20) PRIMARY KEY,GRADE NUMBER(1));
--MARVEL_HERO 테이블에 행 삽입
INSERT INTO MARVEL_HERO VALUES('아이언맨',3);
INSERT INTO MARVEL_HERO VALUES('헐크',1);
INSERT INTO MARVEL_HERO VALUES('스파이더맨',4);
INSERT INTO MARVEL_HERO VALUES('토르',2);
INSERT INTO MARVEL_HERO VALUES('앤트맨',5);
SELECT * FROM MARVEL_HERO;
COMMIT;
두 개의 SELECT 명령으로 검색된 행을 합한 결과를 제공하는 키워드 (중복행 제외)
형식) SELECT 검색대상,... FROM 테이블명 UNION SELECT 검색대상,... FROM 테이블명
두 개의 SELECT 명령은 검색대상의 자료형과 갯수가 반드시 일치하도록 검색
SELECT NAME FROM SUPER_HERO UNION SELECT NAME FROM MARVEL_HERO;
UNION ALL : 두 개의 SELECT 명령으로 검색된 행을 합한 결과를 제공하는 키워드 (중복행 포함)
형식) SELECT 검색대상,... FROM 테이블명 UNION ALL SELECT 검색대상,... FROM 테이블명
SELECT NAME FROM SUPER_HERO UNION ALL SELECT NAME FROM MARVEL_HERO;
두 개의 SELECT 명령으로 검색된 행에서 중복된 결과를 제공하는 키워드
형식) SELECT 검색대상,... FROM 테이블명 INTERSECT SELECT 검색대상,... FROM 테이블명
SELECT NAME FROM SUPER_HERO INTERSECT SELECT NAME FROM MARVEL_HERO;
첫번째 SELECT 명령으로 검색된 행에서 두번째 SELECT 명령의 검색행을 제외한 결과를 제공하는 키워드
형식) SELECT 검색대상,... FROM 테이블명 MINUS SELECT 검색대상,... FROM 테이블명
SELECT NAME FROM SUPER_HERO MINUS SELECT NAME FROM MARVEL_HERO;
SELECT NAME FROM SUPER_HERO UNION SELECT GRADE FROM MARVEL_HERO;
--에러 : 검색대상의 자료형 불일치
SELECT NAME FROM SUPER_HERO UNION SELECT NAME,GRADE FROM MARVEL_HERO;
--에러 : 검색대상의 갯수 불일치
SELECT NAME FROM SUPER_HERO UNION SELECT TO_CHAR(GRADE,'0') FROM MARVEL_HERO;
SELECT NAME,0 FROM SUPER_HERO UNION SELECT NAME,GRADE FROM MARVEL_HERO;
SELECT NAME,NULL FROM SUPER_HERO UNION SELECT NAME,GRADE FROM MARVEL_HERO;