如何解决 Laravel PDO 数据库更新中的'SQLSTATE[HY000]:一般错误”?

Linda Hamilton
发布: 2024-10-23 00:41:31
原创
922 人浏览过

How to Troubleshoot

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

在这篇文章中,我们将深入研究使用 PHP 数据对象 (PDO) 更新数据库时遇到的问题并解决令人困惑的“SQLSTATE[HY000]:一般错误”消息。

问题陈述

提供的代码尝试使用准备好的语句更新数据库。然而,尽管更新成功,却返回错误信息。

$page = 'my_page';
$section = 'content';
$new_content = 'new_content';
$old_content = 'old_content';

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

错误消息

ERROR UPDATING CONTENT: SQLSTATE[HY000]: General error
登录后复制

解决办法

问题出在代码中对 fetchAll() 的调用。 fetchAll() 通常用于从成功的查询中检索数据。但是,对于更新或插入查询,此语句是不必要的。删除它应该可以解决问题。

$result = $stmt->fetchAll(); // <-- Remove this line
登录后复制

删除 fetchAll() 语句后,代码应该成功更新数据库,而不会产生错误消息。

以上是如何解决 Laravel PDO 数据库更新中的'SQLSTATE[HY000]:一般错误”?的详细内容。更多信息请关注PHP中文网其他相关文章!

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