>데이터 베이스 >MySQL 튜토리얼 >LOAD DATA 대 mysqlimport: CSV 파일을 MySQL로 가져오는 가장 좋은 방법은 무엇입니까?

LOAD DATA 대 mysqlimport: CSV 파일을 MySQL로 가져오는 가장 좋은 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-16 09:20:11856검색

LOAD DATA vs. mysqlimport: Which is the Best Way to Import CSV Files into MySQL?

MySQL로 CSV 파일 가져오기: LOAD DATA 및 mysqlimport 탐구

CSV 파일을 MySQL 테이블로 가져오는 문제는 다음과 같은 경우에 발생할 수 있습니다. 정규화되지 않은 데이터와 여러 열을 처리합니다. 이 문제를 해결하려면 가져오기 프로세스의 미묘한 차이를 고려하는 것이 중요합니다.

LOAD DATA 접근 방식

LOAD DATA는 CSV 파일에서 데이터를 가져오는 간단한 방법을 제공합니다. . 그러나 여러 줄에 걸쳐 있는 텍스트 광고문을 적절하게 처리하려면 추가 매개변수를 지정하는 것이 중요합니다. 다음은 줄 바꿈과 관련된 잠재적인 문제를 해결하는 예입니다.

LOAD DATA INFILE "/home/paul/clientdata.csv"
INTO TABLE CSVImport
COLUMNS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '"'
ESCAPED BY '"'
LINES TERMINATED BY '\n'
IGNORE 1 LINES;

이 수정된 문은 줄 종료 문자를 지정하고 열 이름의 첫 번째 줄을 무시하여 잠재적인 문제를 해결합니다.

mysqlimport 유틸리티

CSV 파일을 MySQL로 가져오는 또 다른 옵션은 mysqlimport입니다. 이 목적을 위해 특별히 설계된 명령줄 도구입니다. 이는 대규모 데이터 세트를 가져오는 강력하고 효율적인 방법을 제공합니다.

mysqlimport --ignore-lines=1 \
            --fields-terminated-by=, \
            --local -u root \
            -p Database \
             TableName.csv

이 명령에서 "--ignore-lines=1"은 CSV 파일의 첫 번째 줄(열 이름 포함)을 건너뛰고 "- -fields-terminating-by=,"는 필드 구분 기호를 쉼표로 지정하고, "--local"은 가져오기가 로컬 시스템에서 발생하도록 하며, "-u root -p"는 연결하기 전에 루트 비밀번호를 묻는 메시지를 표시합니다.

추가 고려 사항

필드 구분 기호를 사용자 정의하려면 탭으로 구분된 파일에 대해 "--fields-terminating-by='t'" 옵션을 사용하세요. . 또한 CSV 파일에 이스케이프가 필요한 특수 문자가 포함된 경우 Windows 줄 끝에는 "--lines-terminating-by='r'" 옵션을 사용하고 Unix 줄에는 "--lines-terminating-by='n'" 옵션을 사용하세요. 엔딩.

위 내용은 LOAD DATA 대 mysqlimport: CSV 파일을 MySQL로 가져오는 가장 좋은 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.