首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >当我尝试使用sprintf时,为什么我得到“基表或视图找不到”?

当我尝试使用sprintf时,为什么我得到“基表或视图找不到”?
EN

Stack Overflow用户
提问于 2018-05-31 06:48:24
回答 1查看 29关注 0票数 -2
代码语言:javascript
复制
$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());
}

其他文件:

代码语言:javascript
复制
$query->test('todos', [
    'description' => $_POST['name'] . ' ' . $_POST['lastName'],
    'completed' => isset($_POST['finished'])
]);

这很奇怪,因为如果我手动操作,它会完美地工作

代码语言:javascript
复制
 $sql = "insert into $table (description, completed) values (:description, :completed)";

但是当我使用sprintf和implode时,它给我一个错误,说“基表或视图找不到”,你知道为什么吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-31 07:00:08

因为您使用的是$PHP Documentation For sprintf

代码语言:javascript
复制
$sql = sprintf(
    'insert into %s (%s) values (%s)',
    $table,
    implode(', ', array_keys($parameters)),
    ':' . implode(', :', array_keys($parameters))
);

https://3v4l.org/2oEsT

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50614319

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档