用户输入的数据:
"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个数据更新到数据库,其他数据将保留。
答案 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);
}
}
}