API16:JDatabaseMySQL/updateObject
From Joomla! Documentation
Description
Description
<! removed transcluded page call, red link never existed >
Syntax
updateObject($table, &$object, $keyName, $updateNulls=true)
| Parameter Name | Default Value | Description |
|---|---|---|
| $table | $updateNulls | |
| &$object | ||
| $keyName | ||
| $updateNulls | true |
Defined in
libraries/joomla/database/database/mysql.php
Importing
jimport( 'joomla.database.database.mysql' );
Source Body
public function updateObject($table, &$object, $keyName, $updateNulls=true)
{
$fmtsql = 'UPDATE '.$this->nameQuote($table).' SET %s WHERE %s';
$tmp = array();
foreach (get_object_vars($object) as $k => $v) {
if (is_array($v) or is_object($v) or $k[0] == '_') { // internal or NA field
continue;
}
if ($k == $keyName) {
// PK not to be updated
$where = $keyName . '=' . $this->Quote($v);
continue;
}
if ($v === null) {
if ($updateNulls) {
$val = 'NULL';
} else {
continue;
}
} else {
$val = $this->isQuoted($k) ? $this->Quote($v) : (int) $v;
}
$tmp[] = $this->nameQuote($k) . '=' . $val;
}
$this->setQuery(sprintf($fmtsql, implode(",", $tmp) , $where));
return $this->query();
}
<! removed transcluded page call, red link never existed >
Examples
Code Examples