티스토리 뷰

MySQL

테이블 복사 및 데이터 추가

yoooon1212 2024. 6. 5. 17:13

 

데이터베이스에서 한 테이블의 구조나 데이터를 다른 테이블로 복사하는 작업은 여러 상황에서 유용하게 사용됩니다. 테이블의 구조만을 복사하거나, 구조와 데이터 모두를 복사할 수 있습니다

 

1. 테이블 구조만 복사하기

테이블의 구조만을 새로운 테이블로 복사하고자 할 때, 데이터는 복사하지 않고 구조만 생성합니다.

create table 복사될 테이블명 as select * from 복사 대상 테이블명 where 1 = 0;

 

 

이 쿼리는 기존 테이블의 모든 컬럼을 선택하지만, WHERE 1=0 조건 때문에 어떠한 데이터도 가져오지 않습니다. 결과적으로 컬럼 구조만 복제된 새 테이블이 생성됩니다.

 

 

 

 2. 테이블 구조와 데이터 모두 복사하기

create table 복사될 테이블명 as select * from 복사 대상 테이블명;

 

 

테이블의 구조와 함께 데이터도 새로운 테이블로 복사하려면 다음 쿼리를 사용합니다.

 

주의사항

기본키, 외래키, 인덱스 등의 제약사항은 복사되지 않을 수 있습니다. 따라서, 이러한 제약사항을 수동으로 추가해야 할 필요가 있습니다.

 

 

INSERT INTO SELECT 문 사용

기존 테이블의 데이터를 이용하여 새 데이터를 삽입할 수 있습니다.

 

 

CSV 파일 또는 외부 데이터 소스 사용

대량의 데이터를 처리해야 할 때는 외부 파일(예: CSV)에서 데이터를 읽어와서 데이터베이스 테이블에 삽입하는 방법이 효율적입니다. 대부분의 데이터베이스 시스템에서는 외부 데이터 파일을 삽입할 수 있는 도구나 명령어를 제공합니다.

LOAD DATA INFILE 'path/to/yourfile.csv'
INTO TABLE students
FIELDS TERMINATED BY ','
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
IGNORE 1 ROWS;  -- 첫 번째 행이 헤더일 경우 이 행을 무시

 

'MySQL' 카테고리의 다른 글

Group By 와 having 절  (0) 2024.06.10
Function  (0) 2024.06.07
JOIN(INNER JOIN 과 OUTER JOIN)  (0) 2024.06.05
인덱스(index) 및 관계차수  (0) 2024.06.04
UNIQUE 제약  (0) 2024.06.04
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/12   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
글 보관함