更新数据库时,为什么 fetchAll() 会在 PDO 中导致'SQLSTATE[HY000]: General Error”?

Patricia Arquette
发布: 2024-10-23 00:53:30
原创
952 人浏览过

Why is fetchAll() causing a

更新数据库时 PDO 错误:“SQLSTATE[HY000]:一般错误”

尽管出现错误消息,您的代码似乎已成功更新数据库。问题在于更新或插入查询后使用 fetchAll()。

理解错误

错误消息“SQLSTATE[HY000]:一般错误”提供了有关实际情况的很少信息。问题。它通常表明数据库查询存在一般性问题。

识别问题

在您的代码中,执行更新查询后,您将使用 fetchAll() 来检索结果。此方法通常与选择查询一起使用,它检索查询返回的所有行。但是,对于插入或更新查询,fetchAll() 是不必要的,并且可能会导致错误。

解决方案

要解决该错误,只需删除 fetchAll() 语句即可:

<code class="php">try {
    $stmt = $pdo->prepare("UPDATE $page SET $section = :new_content WHERE $section = '$old_content'");
    $stmt->execute(array(
        'new_content' => $new_content
    ));
    echo "Database updated!";
}
catch(PDOException $e) {
    echo 'ERROR UPDATING CONTENT: ' . $e->getMessage();
}</code>
登录后复制

以上是更新数据库时,为什么 fetchAll() 会在 PDO 中导致'SQLSTATE[HY000]: General Error”?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!