API16

Difference between revisions of "JDatabaseMySQL/insertObject"

From Joomla! Documentation

< API16:JDatabaseMySQL
(New page: ===Description=== Inserts a row into a table based on an objects properties <span class="editsection" style="font-size:76%;"> <nowiki>[</nowiki>[[Description:JDatabaseMySQL/insertObje...)
 
m (removing red link to edit, no existant pages)
(One intermediate revision by one other user not shown)
Line 3: Line 3:
  
 
<span class="editsection" style="font-size:76%;">
 
<span class="editsection" style="font-size:76%;">
<nowiki>[</nowiki>[[Description:JDatabaseMySQL/insertObject|Edit Descripton]]<nowiki>]</nowiki>
+
<nowiki>[<! removed edit link to red link >]</nowiki>
 
</span>
 
</span>
  
{{Description:JDatabaseMySQL/insertObject}}
+
<! removed transcluded page call, red link never existed >
  
 
===Syntax===
 
===Syntax===
Line 21: Line 21:
 
|  The name of the table  
 
|  The name of the table  
 
|-
 
|-
|  
+
| &$object
 
|  
 
|  
 
|  An object whose properties match table fields  
 
|  An object whose properties match table fields  
Line 65: Line 65:
  
 
<span class="editsection" style="font-size:76%;">
 
<span class="editsection" style="font-size:76%;">
<nowiki>[</nowiki>[[SeeAlso:JDatabaseMySQL/insertObject|Edit See Also]]<nowiki>]</nowiki>
+
<nowiki>[<! removed edit link to red link >]</nowiki>
 
</span>
 
</span>
{{SeeAlso:JDatabaseMySQL/insertObject}}
+
<! removed transcluded page call, red link never existed >
  
 
===Examples===
 
===Examples===
Line 80: Line 80:
 
  format= ,,,
 
  format= ,,,
 
</dpl>
 
</dpl>
 +
[[Category:Archived pages API16]]

Revision as of 22:00, 12 May 2013

The "API16" namespace is an archived namespace. This page contains information for a Joomla! version which is no longer supported. It exists only as a historical reference, it will not be improved and its content may be incomplete and/or contain broken links.

Description[edit]

Inserts a row into a table based on an objects properties

[<! removed edit link to red link >]

<! removed transcluded page call, red link never existed >

Syntax[edit]

insertObject($table, &$object, $keyName=NULL)
Parameter Name Default Value Description
$table The name of the table
&$object An object whose properties match table fields
$keyName NULL The name of the primary key. If provided the object property is updated.

Defined in[edit]

libraries/joomla/database/database/mysql.php

Importing[edit]

jimport( 'joomla.database.database.mysql' );

Source Body[edit]

public function insertObject($table, &$object, $keyName = NULL)
{
        $fmtsql = 'INSERT INTO '.$this->nameQuote($table).' (%s) VALUES (%s) ';
        $fields = array();

        foreach (get_object_vars($object) as $k => $v) {
                if (is_array($v) or is_object($v) or $v === NULL) {
                        continue;
                }
                if ($k[0] == '_') { // internal field
                        continue;
                }
                $fields[] = $this->nameQuote($k);
                $values[] = $this->isQuoted($k) ? $this->Quote($v) : (int) $v;
        }
        $this->setQuery(sprintf($fmtsql, implode(",", $fields) ,  implode(",", $values)));
        if (!$this->query()) {
                return false;
        }
        $id = $this->insertid();
        if ($keyName && $id) {
                $object->$keyName = $id;
        }
        return true;
}

[<! removed edit link to red link >] <! removed transcluded page call, red link never existed >

Examples[edit]

<CodeExamplesForm />