[MySQL] csv 파일을 직접 MySQL 테이블로 Import 하는 방법 (대용량 파일 import 팁)

· 10년 전 · 5795

MySQL 테이블에 데이터를 넣는 방법 중 csv 파일을 직접 넣는 방법이 있다.

 

csv 파일과 DB 테이블 구조가 일치하면 아래와 같이 입력하면 된다.

 

LOAD DATA LOCAL INFILE "filePath"

INTO TABLE dbName.tableName FIELDS TERMINATED BY ",";

 

 

만약 파일의 크기가 크고 테이블에 index가 걸려 있으면 시간이 굉장히 오래 걸릴 수 있다.

그럴 경우에는 아래와 같이 index를 먼저 해제해 주고 파일을 올린 다음 다시 index를 걸면 상당히 빠르게 테이블에 데이터를 넣을 수 있다.

 

 

ALTER TABLE dbName.tableName DISABLE KEYS;

LOAD DATA local INFILE "filePath"

INTO TABLE dbName.tableName FIELDS TERMINATED BY ",";

ALTER TABLE dbName.tableName ENABLE KEYS;

 

대략 2GB 정도 되는 파일도 10분 정도로 import가 완료됐다.

 

 

만약 csv 파일 구조와 DB 테이블 구조가 다른 경우는 아래 샘플 sql 문 참조해서 import 한다.

 

 

 

LOAD DATA LOCAL INFILE 'file_name'

INTO TABLE table_name

FIELDS TERMINATED BY ','

ENCLOSED BY '"'

LINES TERMINATED BY '\n'

(column1,column2,column3, ...);

|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

개발자팁

개발과 관련된 유용한 정보를 공유하세요. 질문은 QA에서 해주시기 바랍니다.

+
분류 제목 글쓴이 날짜 조회
PHP 10년 전 조회 3,675
웹서버 10년 전 조회 2,761
PHP 10년 전 조회 7,100
OS 10년 전 조회 3,758
OS 10년 전 조회 2,912
웹서버 10년 전 조회 3,877
PHP 10년 전 조회 7,354
jQuery 10년 전 조회 4,033
기타 10년 전 조회 2,547
기타 10년 전 조회 2,808
기타 10년 전 조회 2,627
기타 10년 전 조회 2,824
기타 10년 전 조회 3,101
기타 10년 전 조회 2,958
MySQL 10년 전 조회 5,796
MySQL 10년 전 조회 4,461
jQuery 10년 전 조회 3,259
웹서버 10년 전 조회 4,518
MySQL 10년 전 조회 2,751
기타 10년 전 조회 2,782
웹서버 10년 전 조회 3,324
웹서버 10년 전 조회 2,800
웹서버 10년 전 조회 3,317
웹서버 10년 전 조회 4,294
MySQL 10년 전 조회 2,468
MySQL 10년 전 조회 3,331
MySQL 10년 전 조회 5,339
MySQL 10년 전 조회 4,911
MySQL 10년 전 조회 3,021
MySQL 10년 전 조회 2,773
🐛 버그신고