sql >> Databasteknik >  >> RDS >> Mysql

Konstruera UPDATE-satser med associativa arrayer i 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
}

Men egentligen borde du använda en ORM för det:

Doktrin 2:Uppdatera fråga med frågebyggaren



  1. Snabba upp MySQL Update/Insert Statement

  2. MySQL:Automatisk ökning av temporär kolumn i select-satsen

  3. Hur får jag textinnehåll från BLOB i Oracle SQL

  4. SQL INSERT INTO... VÄLJ Exempel