집 >데이터 베이스 >MySQL 튜토리얼 >LOAD DATA INFILE을 사용하여 탭으로 구분된 텍스트 파일을 MySQL로 효율적으로 가져오는 방법은 무엇입니까?
데이터 분석 또는 통합 시나리오를 처리할 때 텍스트 파일에서 대규모 데이터 세트를 MySQL로 가져오는 것은 일반적인 작업일 수 있습니다. . 이를 달성하는 가장 효율적인 방법 중 하나는 LOAD DATA INFILE 명령을 사용하는 것입니다.
명령 구조
LOAD DATA INFILE 명령은 특정 구문을 따릅니다.
LOAD DATA INFILE 'file_path' INTO TABLE table_name FIELDS TERMINATED BY 'delimiter' LINES TERMINATED BY 'line_delimiter' (column_list)
탭으로 구분하여 가져오기 데이터
질문에서 언급했듯이 텍스트 파일에는 탭으로 구분된 데이터가 포함되어 있습니다. 기본적으로 LOAD DATA INFILE은 탭을 필드 구분 기호로 가정합니다. 따라서 다음 명령을 사용하여 데이터를 가져와야 합니다.
LOAD DATA INFILE '/tmp/text_file.txt' INTO TABLE PerformanceReport;
구분 기호 지정
파일이 다른 구분 기호를 사용하는 경우 FIELDS TERMINATED BY를 사용하여 지정할 수 있습니다. 절. 예를 들어, 데이터가 쉼표로 구분된 경우:
LOAD DATA INFILE '/tmp/text_file.txt' INTO TABLE PerformanceReport FIELDS TERMINATED BY ','
줄 구분 기호 설정
LINES TERMINATED BY 절은 줄 끝 문자를 지정합니다. 기본적으로 새 줄은 'n'입니다. 파일이 다른 문자를 사용하는 경우 그에 따라 조정하십시오.
LOAD DATA INFILE '/tmp/text_file.txt' INTO TABLE PerformanceReport FIELDS TERMINATED BY ',' LINES TERMINATED BY '\r\n'; # If your file uses CRLF as line delimiter
열 매핑
(column_list) 부분을 사용하면 텍스트 파일과 데이터베이스 테이블의 열. 열의 순서와 개수가 일치하면 이 부분을 생략해도 됩니다.
열 매핑의 예
텍스트 파일에 PerformanceReport 테이블에 없는 추가 열이 있다고 가정합니다. . 명령에서 관련 열만 지정할 수 있습니다.
LOAD DATA INFILE '/tmp/text_file.txt' INTO TABLE PerformanceReport (id, date, value, keyword, cost, clicks) FIELDS TERMINATED BY ',' LINES TERMINATED BY '\r\n';
기타 고려 사항
위 내용은 LOAD DATA INFILE을 사용하여 탭으로 구분된 텍스트 파일을 MySQL로 효율적으로 가져오는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!