sql >> Database >  >> RDS >> Mysql

UPDATE-instructies maken met behulp van associatieve arrays in 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
}

Maar eigenlijk zou je daar een ORM voor moeten gebruiken:

Doctrine 2:Update query met query builder



  1. Zoekcriteria verschil tussen Like vs Bevat() in oracle

  2. Hoe stel je AUTO_INCREMENT in Laravel in met Eloquent?

  3. SQlite Query in Android met cursor

  4. MySQL-juweeltje op OSX 10.7 Lion