0

我将变量设置为 NULL,我试图将其插入数据库,但由于某种原因,它们一直被提交为“0”。我肯定我试图插入的列允许 NULL,并且默认设置为 NULL。这是我的代码:

$insert = NULL;
$query = mysql_query("INSERT INTO `table1` (column1) VALUES ('$insert')") or die(mysql_error());
4

3 回答 3

5

警告:

请不要将mysql_*函数用于新代码。它们不再被维护并且社区已经开始了弃用过程。相反,您应该了解准备好的语句并使用PDOMySQLi

如果您希望它在数据库中NULL(并且您真的仍然使用mysqli_*),您可以执行以下操作:

$insert = NULL;
$query = mysql_query("INSERT INTO `table1` (column1) VALUES ("
                         .(($insert===NULL)?
                                 "NULL":
                                 "'".mysql_real_escape_string($insert)."'").
                     ")") or die(mysql_error());

但这可能会导致恶意 SQL 注入,因此推荐。

鲍比桌


所以:总而言之,您应该使用准备好的语句

你可以像这样使用MySQLi

        $dbHandle = new mysqli(...);
        $query = "INSERT INTO `table1` (column1) VALUES (?)";
        $statement = $dbHandle->prepare($query);
        if($statement){
            $statement->bind_param('s', $insert);
            if(!$statement->execute()){
                echo "Statement insert error: {$statement->error}";
            }
            $statement->close();
        }
        else {
            echo "Insert error: {$dbHandle->error}";
        }
于 2012-07-09T15:26:54.877 回答
1

试试这个静态查询:

$query = mysql_query("INSERT INTO `table1` (column1) VALUES (NULL)")  or die(mysql_error());

使用变量:

$insert= NULL;
$insert = ($insert===NULL)? 'NULL' : "'$insert'";
mysql_query("INSERT INTO `table1` (column1) VALUES ($insert)") or die(mysql_error());
于 2012-07-09T15:26:00.100 回答
0

尝试不带引号;

$query = mysql_query("INSERT INTO `table1` (`column1`) VALUES (".$insert.")") or die(mysql_error()); 

查询应该是;

插入table1column1)值(NULL);

于 2012-07-09T15:24:33.737 回答