Pourquoi fetchAll() provoque-t-il un \'SQLSTATE[HY000] : Erreur générale\' dans PDO lors de la mise à jour d'une base de données ?

Patricia Arquette
Libérer: 2024-10-23 00:53:30
original
952 Les gens l'ont consulté

Why is fetchAll() causing a

Erreur PDO : "SQLSTATE[HY000] : Erreur générale" lors de la mise à jour de la base de données

Malgré le message d'erreur, votre code semble mettre à jour la base de données avec succès. Le problème réside dans l'utilisation de fetchAll() après une requête de mise à jour ou d'insertion.

Comprendre l'erreur

Le message d'erreur "SQLSTATE[HY000] : Erreur générale" fournit peu d'informations sur l'erreur réelle. problème. Cela indique généralement un problème générique avec la requête de base de données.

Identification du problème

Dans votre code, après avoir exécuté la requête de mise à jour, vous utilisez fetchAll() pour récupérer les résultats. Cette méthode est généralement utilisée avec les requêtes de sélection, où elle récupère toutes les lignes renvoyées par la requête. Cependant, pour les requêtes d'insertion ou de mise à jour, fetchAll() n'est pas nécessaire et peut provoquer des erreurs.

Solution

Pour résoudre l'erreur, supprimez simplement l'instruction 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>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!