mirror of
https://github.com/vrana/adminer.git
synced 2025-08-16 19:44:00 +02:00
MS SQL: Fix CSV import (bug #859)
This commit is contained in:
@@ -206,12 +206,16 @@ if (isset($_GET["mssql"])) {
|
||||
foreach ($rows as $set) {
|
||||
$values[] = "(" . implode(", ", $set) . ")";
|
||||
}
|
||||
queries("SET IDENTITY_INSERT " . table($table) . " ON");
|
||||
$return = queries("MERGE " . table($table) . " USING (VALUES\n\t" . implode(",\n\t", $values) . "\n) AS source ($columns) ON " . implode(" AND ", $where) //! source, c1 - possible conflict
|
||||
. ($update ? "\nWHEN MATCHED THEN UPDATE SET " . implode(", ", $update) : "")
|
||||
. "\nWHEN NOT MATCHED THEN INSERT (" . implode(", ", array_keys($set)) . ") VALUES ($columns);" // ; is mandatory
|
||||
);
|
||||
queries("SET IDENTITY_INSERT " . table($table) . " OFF");
|
||||
if ($where) {
|
||||
queries("SET IDENTITY_INSERT " . table($table) . " ON");
|
||||
$return = queries("MERGE " . table($table) . " USING (VALUES\n\t" . implode(",\n\t", $values) . "\n) AS source ($columns) ON " . implode(" AND ", $where) //! source, c1 - possible conflict
|
||||
. ($update ? "\nWHEN MATCHED THEN UPDATE SET " . implode(", ", $update) : "")
|
||||
. "\nWHEN NOT MATCHED THEN INSERT (" . implode(", ", array_keys($set)) . ") VALUES ($columns);" // ; is mandatory
|
||||
);
|
||||
queries("SET IDENTITY_INSERT " . table($table) . " OFF");
|
||||
} else {
|
||||
$return = queries("INSERT INTO " . table($table) . " VALUES\n" . implode(",\n", $values));
|
||||
}
|
||||
return $return;
|
||||
}
|
||||
|
||||
|
@@ -7,6 +7,7 @@ SQLite: Display all rows of variable values
|
||||
SQLite: Remove support for SQLite version 2
|
||||
MS SQL: Support export (bug #480)
|
||||
MS SQL: Display foreign keys ON UPDATE and ON DELETE
|
||||
MS SQL: Fix CSV import (bug #859)
|
||||
MS SQL: Fix altering foreign key
|
||||
MS SQL PDO: Support offset
|
||||
MS SQL: Remove support for MSSQL extension
|
||||
|
Reference in New Issue
Block a user