我有一个函数,它根据要插入该列的列名和值的关联数组以及表名(一个简单的字符串)生成准备好的 INSERT 语句:
function insert ($param, $table) {
$sqlString = "INSERT INTO $table (".implode(', ',array_keys($param)).') VALUES ('.str_repeat('?, ', (count($param) - 1)).'?)';
if ($statement = $this->conn->prepare($sqlString)):
$parameters = array_merge(array($this->bindParams($param), $param));
call_user_func_array(array($statement, 'bind_param', $parameters));
if (!$statement->execute()):
die('Error! '.$statement->error());
endif;
$statement->close();
return true;
else:
die("Could Not Run Statement");
endif;
}
我的问题是 $this->conn->prepare (它是一个类的一部分,conn 是一个新的 mysqli 对象,它可以正常工作)返回 false,但没有给我一个理由!
这是为准备语句构建的示例 $sqlString:
INSERT INTO students (PhoneNumber, FirstName, MiddleInit, LastName, Email, Password, SignupType, Active, SignupDate) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
任何人都可以看到这个参数化语句有问题吗?准备函数返回false的任何原因?