ホームページ > バックエンド開発 > PHPチュートリアル > データベースの更新時に fetchAll() が PDO で「SQLSTATE[HY000]: 一般エラー」を引き起こすのはなぜですか?

データベースの更新時に fetchAll() が PDO で「SQLSTATE[HY000]: 一般エラー」を引き起こすのはなぜですか?

Patricia Arquette
リリース: 2024-10-23 00:53:30
オリジナル
1018 人が閲覧しました

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]: 一般エラー」を引き起こすのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート