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

Konstrukce příkazů UPDATE pomocí asociativních polí v PHP

public function update($tableName, $values, $conditions = array()) {
    if (empty($values)) {
        throw new Exception('Nothing to update');
    }
    $valueStrings = array();
    foreach ($values as $name => $value) {
        $valueStrings[] = $name . ' = :' . $name;
    }
    $conditionStrings = array();
    foreach ($conditions as $column => $value) {
        $conditionString = $column;
        $conditionString .= is_array($value)
            ? ('IN ("' . implode('","', $value) . '")')
            : (' = "' . $value . '"')
        ;
        $conditionStrings[] = $conditionString;
    }
    $sql = 'UPDATE ' . $tableName
        . ' SET ' . implode(', ', $valueStrings)
        . ' WHERE ' . implode(' AND ', $conditionStrings)
    ;
    // execute query
}

Ale ve skutečnosti byste k tomu měli použít ORM:

Doktrína 2:Aktualizace dotazu pomocí nástroje pro tvorbu dotazů



  1. Převeďte nový řádek na XML v rámci Oracle Trigger

  2. Jak dotazovat soundex() v mysql

  3. Vypsat všechny sloupce s možnou hodnotou Null v databázi SQL Server

  4. MySQL - INSERT INTO z dočasné tabulky