Heim >Datenbank >MySQL-Tutorial >Wie importiert man große MySQL-Dateien effizient in Shared Hosting mit PHP?

Wie importiert man große MySQL-Dateien effizient in Shared Hosting mit PHP?

Susan Sarandon
Susan SarandonOriginal
2024-10-28 10:17:02375Durchsuche

How to Efficiently Import Large MySQL Files into Shared Hosting Using PHP?

Effizienter MySQL-Dateiimport in PHP: Aufteilen von Abfragen für Shared Hosting

Im Bereich der Webentwicklung besteht die Notwendigkeit, große Datenbankdateien zu importieren und dabei häufig Shared-Hosting-Anbieter zu verwenden entsteht. Leider kann der Zugriff auf MySQL über die Befehlszeile eingeschränkt sein, sodass eine PHP-basierte Lösung zum Parsen und Ausführen von Abfragen erforderlich ist.

Um dieser Herausforderung zu begegnen, wurde eine robuste Funktion namens SplitSQL() entwickelt, um a zuverlässig aufzuteilen Datenbankdatei in einzelne Abfragen aufteilen, ohne übermäßig viel Speicher zu verbrauchen.

So funktioniert es

SplitSQL() nutzt einen Dateileseansatz und durchläuft die Datei Zeile für Zeile. Es identifiziert Abfragen, indem es das angegebene Trennzeichen (standardmäßig;) am Ende einer Zeile erkennt. Sobald eine vollständige Abfrage zusammengestellt ist, wird sie sofort mit mysql_query() ausgeführt.

Hauptfunktionen

  • Speichereffizient:Dadurch vermieden wird, dass die gesamte Abfrage geladen werden muss Datei in den Speicher, SplitSQL() eignet sich für die Verarbeitung großer Dateien ohne Leistungsprobleme.
  • Fehlertoleranz: Wenn eine Abfrage fehlschlägt, werden Fehlermeldungen zu Debugging-Zwecken angezeigt.
  • Ausgabepufferung:Um eine Speichererschöpfung zu verhindern, löscht SplitSQL() die Ausgabe nach jeder Abfrageausführung.

Verwendungsbeispiel

<code class="php">function SplitSQL($file, $delimiter = ';')
{
    set_time_limit(0);

    if (is_file($file) === true)
    {
        $file = fopen($file, 'r');

        if (is_resource($file) === true)
        {
            $query = array();

            while (feof($file) === false)
            {
                $query[] = fgets($file);

                if (preg_match('~' . preg_quote($delimiter, '~') . '\s*$~iS', end($query)) === 1)
                {
                    $query = trim(implode('', $query));

                    if (mysql_query($query) === false)
                    {
                        echo '<h3>ERROR: ' . $query . '</h3>' . "\n";
                    }

                    else
                    {
                        echo '<h3>SUCCESS: ' . $query . '</h3>' . "\n";
                    }

                    while (ob_get_level() > 0)
                    {
                        ob_end_flush();
                    }

                    flush();
                }

                if (is_string($query) === true)
                {
                    $query = array();
                }
            }

            return fclose($file);
        }
    }

    return false;
}

// Test data
$file = '/path/to/db_dump.sql';
SplitSQL($file);</code>

Das obige ist der detaillierte Inhalt vonWie importiert man große MySQL-Dateien effizient in Shared Hosting mit PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn