1
0
mirror of https://github.com/vrana/adminer.git synced 2025-08-23 14:43:08 +02:00

Allow overwriting tables when copying them

This commit is contained in:
Jakub Vrana
2019-05-14 09:56:29 +02:00
parent f00f7a0e19
commit deea21dd2d
5 changed files with 8 additions and 3 deletions

View File

@@ -810,7 +810,8 @@ if (!defined("DRIVER")) {
queries("SET sql_mode = 'NO_AUTO_VALUE_ON_ZERO'");
foreach ($tables as $table) {
$name = ($target == DB ? table("copy_$table") : idf_escape($target) . "." . table($table));
if (!queries("CREATE TABLE $name LIKE " . table($table))
if (($_POST["overwrite"] && !queries("\nDROP TABLE IF EXISTS $name"))
|| !queries("CREATE TABLE $name LIKE " . table($table))
|| !queries("INSERT INTO $name SELECT * FROM " . table($table))
) {
return false;
@@ -825,7 +826,8 @@ if (!defined("DRIVER")) {
foreach ($views as $table) {
$name = ($target == DB ? table("copy_$table") : idf_escape($target) . "." . table($table));
$view = view($table);
if (!queries("CREATE VIEW $name AS $view[select]")) { //! USE to avoid db.table
if (($_POST["overwrite"] && !queries("DROP VIEW IF EXISTS $name"))
|| !queries("CREATE VIEW $name AS $view[select]")) { //! USE to avoid db.table
return false;
}
}