根据用户从数组输入更新数据库

时间:2016-10-14 01:36:28

标签: php mysql

用户输入的数据:

"product_description": [{
    "language_id": 1,
    "name": "okayt321sd1a"
}

更新数据库:

foreach ($data['product_description'] as $product_description) {
    foreach ($product_description as $key => $value) {
        $a[$key] = $value;

        if($a[$key]){
            $this->db->query("UPDATE " . DB_PREFIX . "product_description SET language_id = '" . (int)$language_id . "', name = '" . $this->db->escape(html_entity_decode($product_description['name'])) . "', meta_keyword = '" . $this->db->escape(html_entity_decode($product_description['meta_keyword'])) . "', meta_description = '" . $this->db->escape(html_entity_decode($product_description['meta_description'])) . "', description = '" . $this->db->escape($product_description['description']) . "', tag = '" . $this->db->escape($product_description['tag']) . "',
                                  page_title = '" . $this->db->escape($product_description['page_title']) . "',
                                  highlight = '" . $this->db->escape($product_description['highlight']) . "',
                                  whatbox = '" . $this->db->escape($product_description['whatbox']) . "' WHERE product_id = '" . (int)$product_id . "', 
                              ");
        }
    }
}

如何根据用户输入更新数据,例如,如果用户输入

"language_id": 1,
"name": "okayt321sd1a"

然后我只更新这2个数据到数据库其他数据将保留,如果输入3个数据:

"language_id": 1,
"name": "okayt321sd1a"
page_title

然后我只将这3个数据更新到数据库,其他数据将保留。

1 个答案:

答案 0 :(得分:1)

你可能想做一个能为你构建sql的函数。我假设您正在使用PDO (我不知道,但此示例使用PDO)。您应该以任何方式绑定参数/值。要添加自定义字段,只需使用array_merge()即可。您可以使用array_diff()unset()删除不需要的值/键:

function updateProductDesc($array,$where,$db)
    {
        foreach($array as $key => $value) {
            $sKey           =   ":{$key}";
            $bind[$sKey]    =   htmlspecialchars($value);
            $sql[]          =   "`{$key}` = {$sKey}";
        }

        $bind[":where"] =   (int) $where;
        $query  =   $db->prepare("UPDATE ".DB_PREFIX."product_description SET ".implode(", ",$sql)." WHERE `product_id` = :where");
        $query->execute($bind);
    }

foreach ($data['product_description'] as $product_description) {
    foreach ($product_description as $key => $value) {
        $a[$key] = $value;
        if($a[$key]){
            updateProductDesc($product_description,$product_id,$this->db);
        }
    }
}