[MSSQL - SELECT 와 INSERT 동시 처리]

편의상 아래와 같은 세개의 테이블이 있다고 가정하겠습니다.

CREATE TABLE [dbo].[table_a] (
[seq] [int] PRIMARY KEY NOT NULL,
[Name] [varchar] (70) NOT NULL,
[Email] [varchar] (70) NOT NULL,
[Idate] [datetime] NOT NULL
)

CREATE TABLE [dbo].[table_b] (
[seq] [int] PRIMARY KEY NOT NULL,
[Name] [varchar] (70) NOT NULL,
[Email] [varchar] (70) NOT NULL,
[Idate] [datetime] NOT NULL
)


CREATE TABLE [dbo].[table_c] (
[seq] [int] PRIMARY KEY NOT NULL,
[Name] [varchar] (70) NOT NULL,
[Nickname] [varchar] (255) NULL,
[Email] [varchar] (70) NOT NULL,
[Tel] [varchar] (20) NULL,
[Idate] [datetime] NOT NULL
)

첫번째와 두번째의 테이블인 table_atable_b 는 컬럼의 갯수 및 데이터형식이 똑 같은 쌍동이 테이블입니다., table_c두개의 컬럼(Nickname, Tel)이 더 추가되어 있는 테이블로 table_atable_c 와는 조금 다른 구조를
가지고 있습니다.



1. 두 테이블의 컬럼이 같을때 SELECT INSERT 하기

두개의 테이블간에 컬럼이 table_a 와 table _b 처럼 완전히 일치할 때는 아래와 같이 간단하게 처리할 수 있습니다.

-- 사용법

INSERT INTO [입력될 테이블명] SELECT * FROM [검색되는 테이블명]

예1) INSERT INTO table_b SELECT * FROM table_a

위의 예1) 에서는 table_a 의 레코드 전체를 table_b 로 삽입(INSERT) 시킵니다. 만약에 조건을 주어 데이터를 삽입(INSERT) 시키려 한다면 아래와 같이 뒤에 WHERE 절만 추가해 주시면 됩니다.

예2)
INSERT INTO table_b SELECT * FROM table_a WHERE seq = 2

위의 SQL 문은 table_a 에서 seq 의 값이 2 인 레코드를 table_b 에 INSERT 시킵니다.



2 . 두 테이블간의 컬럼이 일치하지 않을때 SELECT INSERT 하기


두개의 테이블간에 컬럼이 table_a 와 table _c 처럼 일치하지 않을때는 아래와 같이 컬럼명을 지정해 주시면됩니다.

-- 사용법

INSERT INTO [입력될 테이블명] (컬럼1, 컬럼2, ... ) SELECT 컬럼1, 컬럼2, ... FROM [검색되는 테이블명]

예3) INSERT INTO table_c ( seq, Name, Email, Idate ) SELECT seq, Name, Email, Idate FROM table_a

위의 예3) 에서는 table_a 의 컬럼중 seq, Name, Email, Idate 컬럼을 table_c 에 Insert 시키고 있습니다. 한가지 주의
할 것은 table_c 의 구조가 table_b 와 다른 만큼 INSERT 될 컬럼이 SELECT 되는 컬럼과 일치하지 않으면 아래와 같은
에러가 발생하게 됩니다.

서버: 메시지 213, 수준 16, 상태 4, 줄 1
삽입 오류: 제공된 값의 개수나 열 이름이 테이블 정의와 일치하지 않습니다.




3.
SELECT INTO 를 이용한 데이터 삽입

위에서 설명한 SELECT INSERT 는 테이블의 검색결과를 이미 존재하는 테이블에 삽입(INSERT) 하게됩니다.하지만 SELECT INTO 는 테이블의 검색결과를 INTO 문 다음에 지정한 테이블을 새로 생성시켜서 삽입하게 됩니다. INTO 문 다음의 테이블은 반드시 존재하지 않아야 합니다. 존재하는 테이블이라면 아래와 같은 에러가 발생하게 됩니다.

서버: 메시지 2714, 수준 16, 상태 6, 줄 1
데이터베이스에 'table_d'(이)라는 개체가 이미 있습니다.

-- 사용법

SELECT * INTO [생성될 테이블명] FROM [검색되는 테이블명]

예4) SELECT * INTO table_d FROM table_a

위의 예4) 에서는 table_a 의 내용을 table_d라는 테이블을 새로 생성시켜서 삽입하게 됩니다. 조건절을 추가하려면
검색되는 테이블명 뒤에 추가하면 됩니다.

예5)
SELECT * INTO table_d FROM table_a
WHERE seq = 3

위의 SQL 문은 table_a 에서 seq 의 값이 3인 레코드를 새로 생성되는 table_d 에 INSERT 시킵니다.

 

작성자: 웹마당넷(webmadang@webmadang.net)   http://www.webmadang.net 

'Database > SQL-Server' 카테고리의 다른 글

DBCC 명령어  (0) 2011.06.29
DBCC CHECKDB, CHECKTABLE (손상된 테이블 복구)  (0) 2011.06.27
[MSSQL] 날짜 연산 DATEADD  (0) 2011.05.13
MSSQL dateadd() 이용하여 말일, 초일 구해보자  (0) 2011.05.13
MSSQL Date Type Convert  (0) 2011.05.13

+ Recent posts