mirror of
https://github.com/vrana/adminer.git
synced 2025-08-11 17:14:07 +02:00
Pass primary key to insert_update function
This commit is contained in:
@@ -767,10 +767,10 @@ if (!defined("DRIVER")) {
|
||||
/** Insert or update data in the table
|
||||
* @param string
|
||||
* @param array
|
||||
* @param array
|
||||
* @param array columns in keys
|
||||
* @return bool
|
||||
*/
|
||||
function insert_update($table, $set, $indexes) {
|
||||
function insert_update($table, $set, $primary) {
|
||||
foreach ($set as $key => $val) {
|
||||
$set[$key] = "$key = $val";
|
||||
}
|
||||
|
@@ -467,20 +467,13 @@ WHERE tc.constraint_type = 'FOREIGN KEY' AND tc.table_name = " . $connection->qu
|
||||
return queries("INSERT INTO " . table($table) . ($set ? " (" . implode(", ", array_keys($set)) . ")\nVALUES (" . implode(", ", $set) . ")" : "DEFAULT VALUES"));
|
||||
}
|
||||
|
||||
function insert_update($table, $set, $indexes) {
|
||||
function insert_update($table, $set, $primary) {
|
||||
global $connection;
|
||||
$primary = array();
|
||||
foreach ($indexes as $index) {
|
||||
if ($index["type"] == "PRIMARY") {
|
||||
$primary = array_map("idf_escape", $index["columns"]);
|
||||
break;
|
||||
}
|
||||
}
|
||||
$update = array();
|
||||
$where = array();
|
||||
foreach ($set as $key => $val) {
|
||||
$update[] = "$key = $val";
|
||||
if (in_array($key, $primary)) {
|
||||
if (isset($primary[$key])) {
|
||||
$where[] = "$key = $val";
|
||||
}
|
||||
}
|
||||
|
@@ -492,7 +492,7 @@ if (isset($_GET["sqlite"]) || isset($_GET["sqlite2"])) {
|
||||
return queries("INSERT INTO " . table($table) . ($set ? " (" . implode(", ", array_keys($set)) . ")\nVALUES (" . implode(", ", $set) . ")" : "DEFAULT VALUES"));
|
||||
}
|
||||
|
||||
function insert_update($table, $set, $indexes) {
|
||||
function insert_update($table, $set, $primary) {
|
||||
return queries("REPLACE INTO " . table($table) . " (" . implode(", ", array_keys($set)) . ") VALUES (" . implode(", ", $set) . ")");
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user