$sql = sprintf(
'insert into $s ($s) values ($s)',
$table,
implode(', ', array_keys($parameters)),
':' . implode(', :', array_keys($parameters))
);
try {
$statement = $this->pdo->prepare($sql);
$statement->execute($parameters);
} catch (Exception $e) {
die($e->getMessage());
}
其他文件:
$query->test('todos', [
'description' => $_POST['name'] . ' ' . $_POST['lastName'],
'completed' => isset($_POST['finished'])
]);
这很奇怪,因为如果我手动操作,它会完美地工作
$sql = "insert into $table (description, completed) values (:description, :completed)";
但是当我使用sprintf和implode时,它给我一个错误,说“基表或视图找不到”,你知道为什么吗?
发布于 2018-05-31 07:00:08
因为您使用的是$
。PHP Documentation For sprintf
$sql = sprintf(
'insert into %s (%s) values (%s)',
$table,
implode(', ', array_keys($parameters)),
':' . implode(', :', array_keys($parameters))
);
https://stackoverflow.com/questions/50614319
复制相似问题