sql >> Databáze >  >> RDS >> Mysql

Osvědčený postup:Import souboru mySQL do PHP; rozdělené dotazy

Zde je funkce šetrná k paměti, která by měla být schopna rozdělit velký soubor na jednotlivé dotazy, aniž byste museli otevírat celý soubor najednou :

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

Testoval jsem to na velkém SQL výpisu phpMyAdmin a fungovalo to dobře.

Některá testovací data:

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;

A příslušný výstup:

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;


  1. Nejlepší způsob, jak hostovat MySQL v Azure Cloud

  2. Nelze získat přístup k předvyplněné databázi SQLite pomocí PhoneGap/Cordova v systému Android

  3. SQL dotaz „LIKE“ s použitím „%“, kde vyhledávací kritéria obsahují „%“

  4. Získejte informace o zobrazení pomocí zobrazení informačního schématu VIEWS na serveru SQL Server