Lors de la tentative de mise à jour d'une table à l'aide de la fonction mysqli_update , l'erreur suivante est rencontrée : "Appel à une fonction membre bind_param() sur un non-objet."
L'erreur indique que l'objet $stmt, qui est utilisé pour exécuter l'instruction préparée, n'a pas été correctement créé. Cela peut être dû à un problème avec la requête elle-même.
Pour résoudre ce problème :
Assurez-vous que la syntaxe de la requête est correcte. La requête doit inclure le nom de la table, la clause SET, les paramètres à mettre à jour et la clause WHERE. Vérifiez les fautes de frappe ou les éléments manquants.
Après avoir préparé l'instruction, utilisez les propriétés errno et error de l'objet mysqli pour vérifier s'il y a eu des erreurs lors de la préparation de l'instruction. Si errno n'est pas 0, convertissez le message d'erreur en utilisant mysqli_error() et déclenchez une erreur PHP en utilisant trigger_error() ou lancez une exception.
Assurez-vous que l'instruction préparée est exécutée correctement à l'aide de mysqli_execute(). Recherchez les erreurs lors de l'exécution à l'aide de mysqli_errno() et mysqli_error() après l'exécution de l'instruction.
Voici un exemple de la façon de vérifier les erreurs lors de la préparation et de l'exécution de l'instruction :
if (!($stmt = $mysqli->prepare($query))) { trigger_error($mysqli->error . "[$query]"); } if (!$stmt->execute()) { trigger_error($stmt->error . "[BIND PARAMS: $stmt->errno, EXECUTE: $mysqli->errno]"); }
Par en suivant ces étapes, vous pouvez vous assurer que la requête est syntaxiquement correcte, identifier les erreurs lors de la préparation de l'instruction et confirmer l'exécution de l'instruction. Cela aidera à éviter l'erreur « Appel à une fonction membre bind_param() » lors de la mise à jour des données à l'aide de mysqli.
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!