>  기사  >  데이터 베이스  >  PHP에서 대용량 MySQL 파일을 가져오는 방법: 분할 쿼리 접근 방식을 사용한 메모리 효율적인 솔루션?

PHP에서 대용량 MySQL 파일을 가져오는 방법: 분할 쿼리 접근 방식을 사용한 메모리 효율적인 솔루션?

Barbara Streisand
Barbara Streisand원래의
2024-10-31 04:50:30652검색

How to Import Large MySQL Files in PHP: A Memory-Efficient Solution with Split-Query Approach?

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

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