Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/280.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如果字段为空,如何防止数据发送到数据库?_Php - Fatal编程技术网

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

Php 如果字段为空,如何防止数据发送到数据库?,php,Php,如果某些字段为空,我如何不将数据发送到数据库?现在,如果表单上的某个字段为空,则数据库将用空白数据替换该字段中的任何内容 更新:忘了提一下,如果某些字段留空,这并不重要,这应该是允许的 我的代码 <?php if (isset($_POST['eventname'], $_POST['date'], $_POST['eventvenue'] , $_POST['eventtime'], $_POST['eventcost'])){ $eventname = ($_POST['eventn

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

更新:忘了提一下,如果某些字段留空,这并不重要,这应该是允许的

我的代码

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

您可以阅读PHP函数
empty()

用法示例:

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

正如在评论中所说,不要使用不推荐使用的
mysql.*
函数,请使用或。

您可以阅读PHP函数
empty()

用法示例:

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

正如在评论中所说,不要使用不推荐使用的
mysql.*
函数,请使用或。

您可以阅读PHP函数
empty()

用法示例:

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

正如在评论中所说,不要使用不推荐使用的
mysql.*
函数,请使用或。

您可以阅读PHP函数
empty()

用法示例:

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

正如在评论中所说的,不要使用不推荐的
mysql.*
函数,请使用或。

尝试类似的方法

$query= "UPDATE event set ":

If(isset($var1)){
$query.= " var1=".$var1;
}else if (isset($var2)){

$query.= " var2=".$var2;
}
诸如此类

$result = mysql_query($query);

试试这样的东西

$query= "UPDATE event set ":

If(isset($var1)){
$query.= " var1=".$var1;
}else if (isset($var2)){

$query.= " var2=".$var2;
}
诸如此类

$result = mysql_query($query);

试试这样的东西

$query= "UPDATE event set ":

If(isset($var1)){
$query.= " var1=".$var1;
}else if (isset($var2)){

$query.= " var2=".$var2;
}
诸如此类

$result = mysql_query($query);

试试这样的东西

$query= "UPDATE event set ":

If(isset($var1)){
$query.= " var1=".$var1;
}else if (isset($var2)){

$query.= " var2=".$var2;
}
诸如此类

$result = mysql_query($query);
这是一个使用的示例;它根据字段是否为空(长度为零)构建update语句

然后,执行准备好的语句

$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);
}
这是一个使用的示例;它根据字段是否为空(长度为零)构建update语句

然后,执行准备好的语句

$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);
}
这是一个使用的示例;它根据字段是否为空(长度为零)构建update语句

然后,执行准备好的语句

$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);
}
这是一个使用的示例;它根据字段是否为空(长度为零)构建update语句

然后,执行准备好的语句

$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);
}

使用
!空($variable)
而不是
isset($variable)
(你必须使用
!empty($a)和&!empty($b)
)这些琐碎的东西。(已回答^.^.^.^.^.@Fred ii-祝您在使用
“0”
等值时好运。请不要使用mysql*-函数,这样您的代码就有安全风险。使用例如PDO()。@OP:根据您的编辑“更新:忘了提及,如果某些字段留空则无所谓,这应该是允许的。”您的标题自相矛盾。请使用
!空($variable)
而不是
isset($variable)
(你必须使用
!empty($a)和&!empty($b)
)这些琐碎的东西。(已回答^.^.^.^.^.@Fred ii-祝您在使用
“0”
等值时好运。请不要使用mysql*-函数,这样您的代码就有安全风险。使用例如PDO()。@OP:根据您的编辑“更新:忘了提及,如果某些字段留空则无所谓,这应该是允许的。”您的标题自相矛盾。请使用
!空($variable)
而不是
isset($variable)
(你必须使用
!empty($a)和&!empty($b)
)这些琐碎的东西。(已回答^.^.^.^.^.@Fred ii-祝您在使用
“0”
等值时好运。请不要使用mysql*-函数,这样您的代码就有安全风险。使用例如PDO()。@OP:根据您的编辑“更新:忘了提及,如果某些字段留空则无所谓,这应该是允许的。”您的标题自相矛盾。请使用
!空($variable)
而不是
isset($variable)
(你必须使用
!empty($a)和&!empty($b)
)这些琐碎的东西。(已回答^.^.^.^.^.@Fred ii-祝您在使用
“0”
等值时好运。请不要使用mysql*-函数,这样您的代码就有安全风险。使用例如PDO()。@OP:根据您的编辑“更新:忘了提及,如果某些字段留空,这应该是允许的。”您的标题自相矛盾。我猜:“请不要使用mysql函数,这样您的代码会有安全风险。请改用例如PDO(php.net/manual/en/book.PDO.php)。”小心使用
empty()
-数字零(浮点、整数或字符串)被视为空。如果这是你想要的,就用它。否则,请检查要查找的特定空值。例如,
如果($var===null | |$var===='')
我的猜测:“请不要使用mysql函数,这样你的代码会有安全风险。请使用例如PDO(php.net/manual/en/book.PDO.php)。”小心使用
empty()
-数字零(浮点、整数或字符串)被认为是空的。如果这是你想要的,就用它。否则,请检查要查找的特定空值。例如,
如果($var===null | |$var===='')
我的猜测:“请不要使用mysql函数,这样你的代码会有安全风险。请使用例如PDO(php.net/manual/en/book.PDO.php)。”小心使用
empty()
-数字零(浮点、整数或字符串)被认为是空的。如果这是你想要的,就用它。否则,请检查要查找的特定空值。例如,
如果($var===null | |$var===='')
我的猜测:“请不要使用mysql函数,这样你的代码会有安全风险。请使用例如PDO(php.net/manual/en/book.PDO.php)。”小心使用
empty()
-数字零(浮点、整数或字符串)被认为是空的。如果这是你想要的,就用它。否则,请检查要查找的特定空值。例如,
if($var===null | |$var===='')