使用PHP mysqli进行灵活的“INSERT INTO”查询的方法?

时间:2012-11-20 21:17:00

标签: php mysql mysqli

好的,这有点复杂。

但是现在我正在使用一个homewritten函数来创建一个查询,用于创建一个页面插入数据库。

我想知道是否有更聪明的方法来进行灵活的“插入”方法。

问题是我有一些字段在创建页面时可以输入,所以现在我正在使用这个我在所有字段中运行并检查它们是否已设置。 :

//creates an Array which can be used to make a MySQL query
function createQueryArray($new) {
    if (isset($this->users_id))
        $this->query_array['users_id'] = mysql_real_escape_string($this->users_id);
    if (isset($this->pagename))
        $this->query_array['pagename'] = mysql_real_escape_string($this->pagename);
    if (isset($this->seo_pagetitle))
        $this->query_array['seo_pagetitle'] = mysql_real_escape_string($this->seo_pagetitle);
    if (isset($this->seo_description))
        $this->query_array['seo_description'] = mysql_real_escape_string($this->seo_description);
    if (isset($this->seo_keywords))
        $this->query_array['seo_keywords'] = mysql_real_escape_string($this->seo_keywords);
    if (isset($this->seo_robots))
        $this->query_array['seo_robots'] = mysql_real_escape_string($this->seo_robots);
    if (isset($this->seo_canonical))
        $this->query_array['seo_canonical'] = mysql_real_escape_string($this->seo_canonical);
    if (isset($this->type))
        $this->query_array['page_type'] = mysql_real_escape_string($this->type);
    //$this->query_array['last_edited'] = date("Y-m-d H:i:s");
}

之后我用数组和表格调用此函数我想将页面插入:

function createInsertStm($arr, $table) {
    $mysqlQuery = ("INSERT INTO $table (");
    $insert = "";
    $values = "";
    if (is_array($arr))
        foreach ($arr as $key => $value) {
            if ($insert == "")
                $insert .= $key;
            else
                $insert .= ', ' . $key;
            if ($values == "")
                $values .= (preg_match('/(MAX\(id\))(.*?)/', $value)) ? $value : '"' . $value . '"';
            else
                $values .= (preg_match('/(MAX\(id\))(.*?)/', $value)) ? "," . $value : ',"' . $value . '"';
        }
    $mysqlQuery .= $insert;
    $mysqlQuery .= ') VALUES (';
    $mysqlQuery .= $values;
    $mysqlQuery .= ')';
    return $mysqlQuery;
}

$db->query($queryArray["pages"]);

是否可以使用预先准备好的声明,然后只是跳过一些字段或类似的东西?

1 个答案:

答案 0 :(得分:1)

如果在表定义中设置了默认值,则可以省略insert上的值。

有关默认值的更多信息,请查看以下页面:

http://dev.mysql.com/doc/refman/5.0/en/data-type-defaults.html