在网上搜索后,最终通过扩展
PDOStatement
类得出以下解决方案。请记住,这些功劳归功于
SE
和其他网络来源。
class CustomPDOStatement extends PDOStatement
{
public $removeNulls = FALSE;
public $dbh;
protected function __construct($dbh)
{
$this->dbh = $dbh;
}
public function execute($input_parameters = null)
{
if ($this->removeNulls === TRUE && is_array($input_parameters)) {
foreach ($input_parameters as $key => $value) {
if (is_null($value)) {
$input_parameters[$key] = '';
}
}
}
return parent::execute($input_parameters);
}
public function bindValue($parameter, $value, $data_type = PDO::PARAM_STR)
{
if ($this->removeNulls === TRUE && is_null($value)) {
$value = '';
}
return parent::bindValue($parameter, $value, $data_type);
}
public function bindParam($parameter, &$variable, $data_type = PDO::PARAM_STR, $length = null, $driver_options = null)
{
if ($this->removeNulls === TRUE && is_null($variable)) {
$variable = '';
}
parent::bindParam($parameter, $variable, $data_type, $length, $driver_options);
}
}
在插入或更新时,我是这样做的
$insertUser = $pdoDB->prepare("INSERT INTO users (id,email,name,age) VALUES (:id, :email, :name, :age)");
$insertUser->removeNulls = TRUE;
$insertUser->bindValue(':id', $id);
$insertUser->bindValue(':email', $email);
$insertUser->bindValue(':name', $name);
$insertUser->bindValue(':age', $age);
$insertUser->execute();
为了避免在传递
execute()
的参数时过多地检查
removeNulls
绑定值,可以通过将
array
作为参数传递来实现。
参考以下来源得出这个想法:
- 扩展PDO类。
- 扩展PDOStatement类 和 this。
- 其他网络来源。