更新MySQL记录时如何不包含空白字段

tim*_*tim 2 php mysql forms sql-update

如何在MySQL更新查询中不包括表单的文本字段?我理解为什么它用空字符串替换填充字段,但我不确定一种有效的方法来修复它.最好的选择真的只是很多if陈述吗?是否有某种功能可用于禁止我的html表单中的空白字段?

这是我到目前为止所拥有的:

//Check if record exists
if(mysql_num_rows(mysql_query("SELECT Item_Id FROM Item_t WHERE Item_Id = '$itemid'")) == 0){
    die('The Item ID you entered was not found. Please go back and try again.');
    }

//Update record
$update = "UPDATE Item_t SET Item_Name='$itemname', Item_Price='$itemprice' WHERE Item_Id='$itemid'";
mysql_query($update);
Run Code Online (Sandbox Code Playgroud)

所以基本上,在这个例子中,如果你将字段设置为$itemname空白而只是更新$itemprice,价格将会更新,但名称将设置为空字符串.

Mar*_*ers 5

您可以在SQL中检查字符串是否为空:

UPDATE Item_t
SET Item_Name = IF('$itemname' = '', Item_Name, '$itemname'),
    Item_Price = IF('$itemprice' = '', Item_Price, 'itemprice')
WHERE Item_Id='$itemid'
Run Code Online (Sandbox Code Playgroud)