" . ($val ? $val : lang('skip')) . "" ; } if ($_POST) { $ext = dump_headers((strlen($_GET["dump"]) ? $_GET["dump"] : $_GET["db"]), (!strlen($_GET["db"]) || count(array_filter((array) $_POST["tables"]) + array_filter((array) $_POST["data"])) > 1)); if ($_POST["format"] != "csv") { $max_packet = 1048576; // default, minimum is 1024 echo "SET NAMES utf8;\n"; echo "SET foreign_key_checks = 0;\n"; echo "SET time_zone = '" . $dbh->escape_string($dbh->result($dbh->query("SELECT @@time_zone"))) . "';\n"; echo "\n"; } foreach ($_POST["databases"] as $db => $style) { $db = bracket_escape($db, "back"); if ($dbh->select_db($db)) { if ($_POST["format"] != "csv" && ereg('CREATE', $style) && ($result = $dbh->query("SHOW CREATE DATABASE " . idf_escape($db)))) { if ($style == "DROP, CREATE") { echo "DROP DATABASE IF EXISTS " . idf_escape($db) . ";\n"; } $create = $dbh->result($result, 1); echo ($style == "CREATE, ALTER" ? preg_replace('~^CREATE DATABASE ~', '\\0IF NOT EXISTS ', $create) : $create) . ";\n"; $result->free(); } if ($style && $_POST["format"] != "csv") { echo "USE " . idf_escape($db) . ";\n\n"; $out = ""; if ($dbh->server_info >= 5) { foreach (array("FUNCTION", "PROCEDURE") as $routine) { $result = $dbh->query("SHOW $routine STATUS WHERE Db = '" . $dbh->escape_string($db) . "'"); while ($row = $result->fetch_assoc()) { $out .= $dbh->result($dbh->query("SHOW CREATE $routine " . idf_escape($row["Name"])), 2) . ";;\n\n"; } $result->free(); } } if ($dbh->server_info >= 5.1) { $result = $dbh->query("SHOW EVENTS"); while ($row = $result->fetch_assoc()) { $out .= $dbh->result($dbh->query("SHOW CREATE EVENT " . idf_escape($row["Name"])), 3) . ";;\n\n"; } $result->free(); } echo ($out ? "DELIMITER ;;\n\n$out" . "DELIMITER ;\n\n" : ""); } if (($style || strlen($_GET["db"])) && (array_filter((array) $_POST["tables"]) || array_filter((array) $_POST["data"]))) { $views = array(); $result = $dbh->query("SHOW TABLE STATUS"); while ($row = $result->fetch_assoc()) { $key = (strlen($_GET["db"]) ? bracket_escape($row["Name"]) : 0); if ($_POST["tables"][$key] || $_POST["data"][$key]) { if (isset($row["Engine"])) { if ($ext == "tar") { ob_start(); } dump_table($row["Name"], $_POST["tables"][$key]); dump_data($row["Name"], $_POST["data"][$key]); if ($ext == "tar") { echo tar_file((strlen($_GET["db"]) ? "" : "$db/") . "$row[Name].csv", ob_get_clean()); } elseif ($_POST["format"] != "csv") { echo "\n"; } } elseif ($_POST["format"] != "csv") { $views[$row["Name"]] = $_POST["tables"][$key]; } } } $result->free(); foreach ($views as $view => $style1) { dump_table($view, $style1, true); } } if ($dbh->server_info >= 5 && $style == "CREATE, ALTER" && $_POST["format"] != "csv") { $query = "SELECT TABLE_NAME, ENGINE, TABLE_COLLATION, TABLE_COMMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = DATABASE()"; ?> DELIMITER ;; CREATE PROCEDURE phpminadmin_drop () BEGIN DECLARE _table_name, _engine, _table_collation varchar(64); DECLARE _table_comment varchar(64); DECLARE done bool DEFAULT 0; DECLARE tables CURSOR FOR ; DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; OPEN tables; REPEAT FETCH tables INTO _table_name, _engine, _table_collation, _table_comment; IF NOT done THEN CASE _table_namequery($query); while ($row = $result->fetch_assoc()) { $comment = $dbh->escape_string($row["ENGINE"] == "InnoDB" ? preg_replace('~(?:(.+); )?InnoDB free: .*~', '\\1', $row["TABLE_COMMENT"]) : $row["TABLE_COMMENT"]); echo " WHEN '" . $dbh->escape_string($row["TABLE_NAME"]) . "' THEN " . (isset($row["ENGINE"]) ? "IF _engine != '$row[ENGINE]' OR _table_collation != '$row[TABLE_COLLATION]' OR _table_comment != '$comment' THEN ALTER TABLE " . idf_escape($row["TABLE_NAME"]) . " ENGINE=$row[ENGINE] COLLATE=$row[TABLE_COLLATION] COMMENT='$comment'; END IF" : "BEGIN END") . ";"; } $result->free(); ?> ELSE SET @alter_table = CONCAT('DROP TABLE `', REPLACE(_table_name, '`', '``'), '`'); PREPARE alter_command FROM @alter_table; EXECUTE alter_command; -- returns "can't return a result set in the given context" with MySQL extension DROP PREPARE alter_command; END CASE; END IF; UNTIL done END REPEAT; CLOSE tables; END;; DELIMITER ; CALL phpminadmin_drop; DROP PROCEDURE phpminadmin_drop; $_GET["export"]) : array()), $_GET["db"]); ?>

\n" . lang('Database') . ""; foreach (array('', 'USE', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo '' . dump_link("db_check", "databases", $val) . ''; } echo "\n"; foreach ((strlen($_GET["db"]) ? array($_GET["db"]) : get_databases()) as $db) { if ($db != "information_schema" || $dbh->server_info < 5) { echo "" . htmlspecialchars($db) . ""; foreach (array('', 'USE', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo '"; } echo "\n"; } } echo "\n"; echo "\n"; foreach (array('', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { echo ''; } foreach (array('', 'TRUNCATE, INSERT', 'INSERT', 'UPDATE') as $val) { echo ''; } echo "\n"; $views = ""; $result = $dbh->query(strlen($_GET["db"]) ? "SHOW TABLE STATUS" : "SELECT 'Engine'"); odd(''); while ($row = $result->fetch_assoc()) { $print = ""; foreach (array('', 'DROP, CREATE', 'CREATE', 'CREATE, ALTER') as $val) { $print .= '"; } if (!$row["Engine"]) { $views .= "$print\n"; } else { foreach (array('', 'TRUNCATE, INSERT', 'INSERT', 'UPDATE') as $val) { $print .= '"; } echo "$print\n"; } } echo "$views
" . lang('Tables') . "" . lang('Structure') . "" . lang('Data') . "
' . dump_link("table_check", "tables", $val) . '' . dump_link("data_check", "data", $val, ($val == 'UPDATE' ? " title='INSERT INTO ... ON DUPLICATE KEY UPDATE'" : "")) . '
" . htmlspecialchars($row["Name"]) . "
\n"; ?>