이 질문은 PHP를 사용하여 CSV 데이터를 MySQL 데이터베이스로 가져올 때 발생하는 몇 가지 문제를 해결합니다.
제공된 코드는 CSV 파일을 효과적으로 업로드하고 해당 내용을 표시합니다. 그러나 데이터베이스에서 텍스트 데이터가 0으로 표시되는 문제와 가져온 데이터를 따옴표로 묶을 가능성이 있는 문제에 직면합니다.
1. 0으로 표시되는 텍스트 필드
이 문제를 해결하려면 CSV 파일의 인코딩을 확인하세요. 텍스트와 숫자 데이터를 모두 지원하는 UTF-8인지 확인하세요. 또한 데이터베이스 테이블 열이 텍스트 데이터를 허용하도록 올바르게 정의되었는지 확인하세요.
2. 인용 데이터
인용은 CSV 파일에 데이터를 포함할 수 있습니다. 이 문제가 발생하면 mysql_real_escape_string을 사용하여 데이터를 데이터베이스에 삽입하기 전에 데이터를 정리할 수 있습니다. SQL 인젝션 공격을 방지하기 위해 따옴표를 포함한 특수 문자를 이스케이프하는 기능입니다.
3. 헤더 줄 무시
헤더가 포함될 수 있는 CSV 파일의 첫 번째 X 줄을 건너뛰려면 가져오기 프로세스를 시작하기 전에 fseek 및 fgetc를 사용하여 파일을 수동으로 진행하세요.
4. 데이터 형식
데이터 형식은 가져오기 프로세스 전체에서 동일하게 유지되어야 합니다. 소수를 포함한 숫자 값은 원래 형식으로 유지됩니다. 그러나 MySQL에는 다양한 형식(예: 십진수, 부동 소수점 등)에 대한 특정 데이터 유형이 있으므로 이에 따라 데이터베이스 열을 정의하는 것이 중요합니다.
5. 성능 문제
보고된 "치명적인 오류"는 PHP의 실행 시간 제한(30초)을 초과했음을 나타냅니다. 이는 대규모 데이터 세트를 가져올 때 일반적으로 발생합니다. 이 문제를 해결하려면 PHP 구성 파일(php.ini)에서 max_execution_time 설정을 늘리거나 청크 분할 가져오기 메커니즘을 구현하여 여러 요청에 걸쳐 데이터를 더 작은 부분으로 처리할 수 있습니다.
대체 방법
답변에서 제안한 대로 MySQL의 LOAD DATA INFILE 기능을 사용하는 것을 고려해 볼 수 있습니다. 이를 통해 단일 SQL 쿼리를 사용하여 CSV 데이터를 직접 가져올 수 있어 성능이 향상되고 PHP 처리 루프가 필요하지 않습니다.
위 내용은 PHP/MySQL에서 CSV 데이터 가져오기 문제를 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!