如果某些字段为空,我将如何不将数据发送到数据库?从现在开始,如果表单上的字段为空,则数据库将使用空白数据替换字段中的任何内容
更新:忘记提及,如果某些字段留空是无关紧要的,应该允许。
我的代码
<?php
if (isset($_POST['eventname'], $_POST['date'], $_POST['eventvenue'] , $_POST['eventtime'], $_POST['eventcost'])){
$eventname = ($_POST['eventname']);
$eventdate = ($_POST['date']);
$eventtime = ($_POST['eventtime']) . ":00";
$eventvenue = ($_POST['eventvenue']);
$eventcost = ($_POST['eventcost']);
$result = mysql_query("UPDATE event set event_name = '" . $eventname . "', event_date = '" . $eventdate . "', event_time = '" . $eventtime . "', event_venue = '" . $eventvenue ."', event_cost = '" . $eventcost ."'");
}
?>
答案 0 :(得分:1)
您可以阅读PHP的函数empty()
使用示例:
if(empty($eventname))
{
echo "You have not set event name";
} else {
mysqli_query(...);
}
答案 1 :(得分:1)
尝试像This
这样的东西$query= "UPDATE event set ":
If(isset($var1)){
$query.= " var1=".$var1;
}else if (isset($var2)){
$query.= " var2=".$var2;
}
等等然后
$result = mysql_query($query);
答案 2 :(得分:1)
这是使用prepared statements的示例;它根据字段是否为空(零长度)构建更新语句。
之后,执行准备好的声明。
$updates = [];
$parameters = [];
if (strlen($_POST['eventname'])) {
$updates[] = 'event_name = ?';
$parameters[] = $_POST['eventname'];
}
// ...
if (strlen($_POST['eventtime'])) {
$updates[] = "event_time = ?";
$parameters[] = $_POST[$field] . ':00';
}
if ($updates) {
$sql = sprintf('UPDATE event SET %s WHERE xxx', join(',', $updates));
$stmt = $db->prepare($sql);
$stmt->execute($parameters);
}