mssql 에서는 bcp 라는 툴을 통해 csv 형식의 데이터들을 테이블에 추가할 수 있다. mysql 에서는 load data 라는 sql 명령어를 사용한다.
https://dev.mysql.com/doc/refman/8.0/en/load-data.html
use test;
create table if not exists bulkinsert
(
seq_id bigint not null auto_increment primary key,
col_char_1 char(64) COLLATE utf8mb4_bin NOT NULL COMMENT 'col1',
col_bigint_2 bigint NOT NULL COMMENT 'col2',
col_char_3 char(64) COLLATE utf8mb4_bin NOT NULL COMMENT 'col3'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;
예를 들어 test db 에 bulkinsert 라는 테이블을 만들고 데이터를 추가해보자.
load data local infile 'D:/test/work/test/bulkinsert.csv' # 경로
replace into table bulkinsert # 테이블명
lines terminated by '\n' # 열 구분자
(col_char_1, col_bigint_2, col_char_3); # 칼럼 목록
추가할 데이터 파일의 절대 경로를 적어주고 대상 테이블, 열 구분자, 칼럼 목록을 적어주면 된다.
Error Code: 2068. LOAD DATA LOCAL INFILE file request rejected due to restrictions on access.
별 문제없이 실행되면 좋겠지만 기본 설정으로 실행하면 위와 같은 오류 메시지가 보일 수 있다.
MySQL Workbench 를 사용 중이라면 Edit Connection > Connection > Advanced 에 OPT_LOCAL_INFILE=1 을 추가하자. mysql cli 를 사용 중이라면 --local-infile=1 을 실행 파라미터에 추가하자.
P.S. 내 개발환경에서는 대문자로 해야했다. 테이블 이름 같은 경우 윈도 버전은 대소문자 안가리고 리눅스는 가렸는데 실행 파람은 좀 특이했다.
https://java119.tistory.com/55
728x90