我正在使用这段代码,但已经非常沮丧了:
try {
$dbh = new PDO('mysql:dbname=' . DB . ';host=' . HOST, USER, PASS);
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES 'utf8'");
}
catch(PDOException $e)
{
...
}
$stmt = $dbh->prepare('INSERT INTO table(v1, v2, ...) VALUES(:v1, :v2, ...)');
$stmt->bindParam(':v1', PDO::PARAM_NULL); // --> Here's the problem
PDO::PARAM_NULL, null, '',
这些都失败了并抛出了以下错误:
Fatal error: 在 /opt/... 中不能通过引用传递参数2。
bindValue()
而不是bindParam()
;对于所有内容,而不仅仅是NULL
值。我想不出任何需要将参数绑定到PHP变量的引用的情况 - 但这就是bindParam()
的作用。 - low_rents