如果字段为空,如何防止数据发送到数据库?

时间:2014-01-13 14:44:08

标签: php

如果某些字段为空,我将如何不将数据发送到数据库?从现在开始,如果表单上的字段为空,则数据库将使用空白数据替换字段中的任何内容

更新:忘记提及,如果某些字段留空是无关紧要的,应该允许。

我的代码

<?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 ."'");
}
?>

3 个答案:

答案 0 :(得分:1)

您可以阅读PHP的函数empty()

empty() on PHP.net

使用示例:

if(empty($eventname))
{
    echo "You have not set event name";
} else {
    mysqli_query(...);
}

如评论所述,请勿使用已弃用的mysql_*函数,使用mysqli_*PDO

答案 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);
}