Allow wpdb->update() to optionally take a named array of where column/value pairs (which will be ANDed)
git-svn-id: http://svn.automattic.com/wordpress/trunk@6239 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
1d883e1b9c
commit
f18e02b0f0
|
@ -266,17 +266,24 @@ class wpdb {
|
||||||
* Update a row in the table with an array of data
|
* Update a row in the table with an array of data
|
||||||
* @param string $table WARNING: not sanitized!
|
* @param string $table WARNING: not sanitized!
|
||||||
* @param array $data should not already be SQL-escaped
|
* @param array $data should not already be SQL-escaped
|
||||||
* @param string $where_col the column of the WHERE statement. WARNING: not sanitized!
|
* @param mixed $where_col_or_array if a string, it represents the column of the WHERE statement. If an array (named), it can represent multiple col = 'value' pairs that will be joined with ANDs WARNING: the column names are not sanitized!
|
||||||
* @param string $where_val the value of the WHERE statement. Should not already be SQL-escaped.
|
* @param string $where_val the value of the WHERE statement. Should not already be SQL-escaped.
|
||||||
* @return mixed results of $this->query()
|
* @return mixed results of $this->query()
|
||||||
*/
|
*/
|
||||||
function update($table, $data, $where_col, $where_val){
|
function update($table, $data, $where_col_or_array, $where_val=NULL){
|
||||||
$data = add_magic_quotes($data);
|
$data = add_magic_quotes($data);
|
||||||
$bits = array();
|
$bits = $wheres = array();
|
||||||
foreach ( array_keys($data) as $k )
|
foreach ( array_keys($data) as $k )
|
||||||
$bits[] = "`$k`='$data[$k]'";
|
$bits[] = "`$k` = '$data[$k]'";
|
||||||
$where_val = $this->escape($where_val);
|
|
||||||
return $this->query("UPDATE $table SET ".implode(', ',$bits)." WHERE $where_col = '$where_val' LIMIT 1");
|
if ( is_string( $where_col_or_array ) )
|
||||||
|
$wheres = array( "$where_col_or_array = '" . $this->escape($where_val) . "'" );
|
||||||
|
elseif ( is_array( $where_col_or_array ) )
|
||||||
|
foreach ( $where_col_or_array as $c => $v )
|
||||||
|
$wheres[] = "$c = '" . $this->escape( $v ) . "'";
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
return $this->query( "UPDATE $table SET " . implode( ', ', $bits ) . ' WHERE ' . implode( ' AND ', $wheres ) . ' LIMIT 1' );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue