update page now
Laravel Live Japan

PDOStatement::errorCode

(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.1.0)

PDOStatement::errorCode Récupère les informations sur l'erreur associée lors de la dernière opération sur la requête

Description

public PDOStatement::errorCode(): ? string

Liste de paramètres

Cette fonction ne contient aucun paramètre.

Valeurs de retour

Identique à PDO::errorCode() , excepté que PDOStatement::errorCode() récupère uniquement les codes erreurs pour les opérations sur les objets PDOStatement.

Exemples

Exemple #1 Détermine la catégorie de l'erreur qui survient

<?php
/* Provoque une erreur -- la table BONES n'existe pas */
$err = $dbh->prepare('SELECT skull FROM bones');
$err->execute();

echo
"\nPDOStatement::errorCode(): ";
print
$err->errorCode();
?>

L'exemple ci-dessus va afficher :

PDOStatement::errorCode(): 42S02

Voir aussi

  • PDO::errorCode() - Retourne le SQLSTATE associé avec la dernière opération sur la base de données
  • PDO::errorInfo() - Retourne les informations associées à l'erreur lors de la dernière opération sur la base de données
  • PDOStatement::errorInfo() - Récupère les informations sur l'erreur associée lors de la dernière opération sur la requête

Found A Problem?

Learn How To Improve This PageSubmit a Pull RequestReport a Bug
+add a note

User Contributed Notes 2 notes

up
15
vaclav dot sir at gmail dot com
19 years ago
Statement's errorCode() returns an empty string before execution, and '00000' (five zeros) after a sucessfull execution:
<?php
$stmt = $pdo->prepare($query);
assert($stmt->errorCode === '');
$stmt->execute();
assert($stmt->errorCode === '00000');
?>
up
-1
dbeecher at tekops dot com
17 years ago
Neither this property nor the PDOStatement::errorInfo() properties are available if you create your own exception handler.
I am using PHP 5.2.4, PDO_INFORMIX 1.2.0.
Making this call at any point in the program after setting your own exception handler produces an error:
PHP Notice: Undefined property: PDOStatement::$errorCode in new_query.php on line
or
PHP Notice: Undefined property: PDOStatement::$errorInfo in new_query.php on line
But if I set the PDO to SILENT, only set error codes with:
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT)
Then process with if/else the call to this functions works fine. The examples below only do error checking to show the result codes of this function. Normally you would want more.
FAILS:
$dbh = new PDO("informix...")
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
try {
 $result = $dbh->query("asdfkjasdfkjasdfjk"); /* obvious sql error */
 if ($result) print "success!";
 }
catch
 {
 $myeCode = $dbh->errorCode();
 /* do stuff with error */
 };
$dbh=0;
The error handler gets called but knows nothing about $dbh->errorCode or $dbh->errorInfo.
WORKS:
$dbh = new PDO("informix...")
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_SILENT);
$result = $dbh->query("asdfkjasdfkjasdfjk"); /* obvious sql error */
if ($result) 
 {
 /* process result */
 print "success!";
 /* all done, didn't make any changes */
 $dbh->rollback();
 }
else
 {
 $myeCode = $dbh->errorCode();
 print_r($myeCode);
 };
$dbh=0; /* close connection */
I hope this helps someone else.
Cheers,
David
+add a note

AltStyle によって変換されたページ (->オリジナル) /