sql >> Database teknologi >  >> RDS >> Mysql

Konstruktion af UPDATE-sætninger ved hjælp af associative arrays 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 faktisk burde du bruge en ORM til det:

Doktrin 2:Opdater forespørgsel med forespørgselsbygger



  1. Introduktion til Row-Level Security i SQL Server

  2. Hvordan læser jeg denne tekstfil og indsætter i MySQL?

  3. Kan ikke oprette forbindelse til MySQL Workbench på mac. Kan ikke oprette forbindelse til MySQL-server på '127.0.0.1' (61) Mac Macintosh

  4. Få det aktuelle login-id i SQL Server (T-SQL)