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 중국어 웹사이트의 기타 관련 기사를 참조하세요!