PHP에서 대용량 MySQL 파일 가져오기: 포괄적인 분할 쿼리 솔루션
공유 호스팅 제공업체 웹사이트로 대용량 MySQL 파일을 가져오면 다음과 같은 이점이 있습니다. 특히 PHP를 사용하고 MySQL에 대한 외부 액세스가 제한되는 경우에는 문제가 됩니다. 이 문서에서는 파일을 가져올 개별 쿼리로 안정적으로 분할하여 이 문제를 해결하는 포괄적인 솔루션을 제공합니다.
고려해야 할 과제
대용량 MySQL 파일을 구문 분석하고 쿼리할 때 PHP에서는 다음과 같은 몇 가지 과제가 발생합니다.
신뢰할 수 있는 분할 쿼리 솔루션
이러한 과제를 극복하기 위해 이 기사에서는 SplitSQL()이라는 메모리 친화적인 함수를 소개합니다. 이 함수는 파일을 한 줄씩 읽고 쿼리 구분 기호(예: 세미콜론)가 나타날 때까지 개별 쿼리를 누적합니다. 코드는 다음과 같습니다.
function SplitSQL($file, $delimiter = ';') { set_time_limit(0); if (is_file($file) && is_resource($file = fopen($file, 'r'))) { $query = array(); while (!feof($file)) { $query[] = fgets($file); if (preg_match('~' . preg_quote($delimiter, '~') . '\s*$~iS', end($query))) { $query = trim(implode('', $query)); if (mysql_query($query) === false) { echo 'ERROR: ' . $query . "\n"; } else { echo 'SUCCESS: ' . $query . "\n"; flush(); } $query = array(); } } fclose($file); return true; } return false; }
메모리 친화적이고 테스트됨
이 함수는 필요한 경우에만 메모리를 할당하여 메모리 문제를 방지합니다. 대규모 phpMyAdmin SQL 덤프에서 테스트되어 실제 데이터를 효과적으로 처리하는 능력이 입증되었습니다.
테스트 데이터 및 출력
샘플 데이터 및 해당 출력은 다음을 사용합니다. SplitSQL() 함수:
테스트 데이터:
CREATE TABLE IF NOT EXISTS "test" ( "id" INTEGER PRIMARY KEY AUTOINCREMENT, "name" TEXT, "description" TEXT ); BEGIN; INSERT INTO "test" ("name", "description") VALUES (";;;", "something for you mind; body; soul"); COMMIT; UPDATE "test" SET "name" = "; " WHERE "id" = 1;
출력:
SUCCESS: CREATE TABLE IF NOT EXISTS "test" ( "id" INTEGER PRIMARY KEY AUTOINCREMENT, "name" TEXT, "description" TEXT ); SUCCESS: BEGIN; SUCCESS: INSERT INTO "test" ("name", "description") VALUES (";;;", "something for you mind; body; soul"); SUCCESS: COMMIT; SUCCESS: UPDATE "test" SET "name" = "; " WHERE "id" = 1;
결론
SplitSQL() 기능은 대용량 MySQL 파일을 개별 쿼리로 분할하기 위한 강력하고 안정적인 솔루션을 제공하여 공유 호스팅 환경에서 효율적이고 자동화된 데이터베이스 가져오기를 가능하게 합니다. 이 기능은 메모리 제약을 해결하고 다양한 데이터 유형을 고려하여 PHP에서 대용량 MySQL 파일을 가져오는 복잡한 프로세스를 단순화합니다.
위 내용은 PHP에서 대용량 MySQL 파일을 가져오는 방법: 분할 쿼리 접근 방식을 사용한 메모리 효율적인 솔루션?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!