Rumah  >  Artikel  >  pangkalan data  >  Bagaimana Mengimport Fail MySQL Besar dalam PHP: Penyelesaian Cekap Memori dengan Pendekatan Split-Query?

Bagaimana Mengimport Fail MySQL Besar dalam PHP: Penyelesaian Cekap Memori dengan Pendekatan Split-Query?

Barbara Streisand
Barbara Streisandasal
2024-10-31 04:50:30652semak imbas

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

Mengimport Fail MySQL Besar dalam PHP: Penyelesaian Split-Query Komprehensif

Mengimport fail MySQL yang besar ke dalam laman web penyedia pengehosan kongsi boleh menjadi satu cabaran, terutamanya apabila menggunakan PHP dan akses luaran kepada MySQL adalah terhad. Artikel ini menyediakan penyelesaian komprehensif yang menangani isu ini dengan membahagikan fail kepada pertanyaan individu untuk import dengan pasti.

Cabaran untuk Dipertimbangkan

Apabila menghuraikan dan menanya fail MySQL yang besar dalam PHP, beberapa cabaran timbul:

  • Mengesan pembatas medan dalam data
  • Mengendalikan pemisah baris dalam medan memo
  • Mengelakkan masalah memori disebabkan saiz fail yang besar

Penyelesaian Split-Query yang Boleh Dipercayai

Untuk mengatasi cabaran ini, artikel ini memperkenalkan fungsi mesra memori yang dipanggil SplitSQL(). Fungsi ini membaca fail baris demi baris dan mengumpul pertanyaan individu sehingga pembatas pertanyaan (seperti koma bernoktah) ditemui. Berikut ialah kod:

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;
}

Mesra Memori dan Diuji

Fungsi ini memperuntukkan memori hanya apabila diperlukan, mengelakkan masalah ingatan. Ia telah diuji pada lambakan SQL phpMyAdmin yang besar, menunjukkan keupayaannya untuk mengendalikan data dunia sebenar dengan berkesan.

Data dan Output Ujian

Data sampel dan output masing-masing menggunakan fungsi SplitSQL():

Data Ujian:

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;

Output:

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;

Kesimpulan

Fungsi SplitSQL() menyediakan penyelesaian yang mantap dan boleh dipercayai untuk memisahkan fail MySQL yang besar kepada pertanyaan individu, membenarkan import pangkalan data yang cekap dan automatik dalam persekitaran pengehosan dikongsi. Dengan menangani kekangan memori dan mengambil kira pelbagai jenis data, fungsi ini memudahkan proses kompleks mengimport fail MySQL yang besar dalam PHP.

Atas ialah kandungan terperinci Bagaimana Mengimport Fail MySQL Besar dalam PHP: Penyelesaian Cekap Memori dengan Pendekatan Split-Query?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn