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:
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!