6

我需要更新一个数据库,并execute()通过给它一个数组作为参数来使用 PDO 的方法。

这个想法是它在尝试插入NULL值时给我一个错误......

这是发送的查询/参数的示例:

生成的查询:

UPDATE table SET name=?, id_extra1=?, id_extra2=? WHERE id_something=?

参数数组:

array (size=8)
  'name' => string 'testing' (length=6)
  'id_extra1' => string '2' (length=1)
  'id_extra2' => null
  'id_something' => string '1958' (length=4)

所以NULL价值是id_extra2

在我的代码中,id_extra2我有这样的条件(想法是我有一个 ID 或 0,然后我必须用 更新 DB 值NULL

if ($_POST['id_extra2']==0) {
    $_POST['id_extra2'] = null;
}

我尝试设置$_POST['id_extra2']to''和 to NULL'null'但它仍然无法正常工作。

4

2 回答 2

2

请考虑使用 bindValue 而不是传递数组来执行。正如这里所说:

所有值都被视为 PDO::PARAM_STR。

应该可以使这对您的应用程序的其余部分非常透明,因为您已经拥有要更新为数组的值。尝试例如这样的事情:

<?php
function executeWithDataTypes(PDOStatement $sth, array $values) {
    $count = 1;
    foreach($values as $value) {
        $sth->bindValue($count, $values['value'], $values['type']);
        $count++;
    }

    return $sth->execute();
}

$sth = $handle->prepare("UPDATE table SET name = ?, id_extra1 = ?, id_extra2 = ? WHERE id_something = ?");

$values = array();
$values[] = array('value' => 'testing', 'type' => PDO::PARAM_STR);
$values[] = array('value' => 2, 'type' => PDO::PARAM_INT);
$values[] = array('value' => null, 'type' => PDO::PARAM_NULL);
$values[] = array('value' => 1958, 'type' => PDO::PARAM_INT);

$result = executeWithDataTypes($sth, $values);
?>

正如您所指出的,过去使用 bindParam 让您头疼,请注意bindValuebindParam之间的细微差别。就我个人而言,我从不使用 bindParam,因为它的副作用使脚本更难理解,尽管当然在某些情况下这些效果会派上用场。

编辑:您当然可以进一步简化函数,并通过执行以下操作摆脱将类型指定为传递数组中的附加键的需要:

$type = PDO::PARAM_STR;
switch(true) {
    case is_null($value): $type = PDO::PARAM_NULL; break;
    case is_numeric($value): $type = PDO::PARAM_INT; break;
    // ...
    default: break;
}

并根据数组中传入的值的类型确定类型;然而,这更容易出错,因为例如浮点数也是数字,这会导致上述 switch 语句中的错误决定,但我想为了完整起见我会提到它。

于 2013-07-18T13:21:00.380 回答
0

没有这样的问题。

只需将您的空值发送到数据库中

不需要特殊功能,也不需要复杂的过度设计的解决方案。

它只是工作。任何方法 -execute()bindValue()-bindParam()使用您希望的任何一种方法。您所需要的只是一个null值。然后在查询中使用它作为任何其他值。

$null = null;
$stmt = $pdo->prepare("INSERT INTO table (id) VALUES (?)");
$stmt->execute([$null]);

$stmt->bindParam(1, $null);
$stmt->execute();

$stmt->bindValue(1, $null);
$stmt->execute();

所有工作

于 2021-02-13T07:55:20.283 回答