Php pdo error handling. The object-oriented method first looks at the handling of connection errors and PDO errors in PHP. the object-oriented method is used for processing: Copy the code as follows :? Phptry {$ dbnewPD object-oriented method
First, let's take a look at the handling of connection errors and PDO errors in PHP, and use object-oriented methods to handle them:
The code is as follows:
Try {
$ Db = new PDO ('MySQL: host = localhost; dbname = test', $ user, $ pass );
$ Db = null;
} Catch (PDOException $ e ){
Print "Error:". $ e-> getMessage ()."
";
Die ();
}
?>
Here we use the object-oriented exception handling feature of PHP 5. if there is an exception in it, we will initialize and call PDOException to initialize an exception class.
The property structure of the PDOException class:
The code is as follows:
Class PDOException extends Exception
{
Public $ errorInfo = null; // error message, which can be accessed by calling PDO: errorInfo () or PDOStatement: errorInfo ()
Protected $ message; // Exception information. you can try Exception: getMessage () to access
Protected $ code; // SQL status error code, which can be accessed using Exception: getCode ()
}
?>
This exception handling class is integrated with the PHP 5 built-in exception handling class. let's take a look at the PHP 5 built-in exception handling class structure:
The code is as follows:
Class Exception
{
// Attributes
Protected $ message = 'unknown exception'; // exception information
Protected $ code = 0; // custom exception code
Protected $ file; // file name with an exception
Protected $ line; // The code line number with an exception
// Method
Final function getMessage (); // returns exception information
Final function getCode (); // returns the exception code
Final function getFile (); // returns the file name with an exception
Final function getLine (); // return the code line number in which an exception occurs.
Final function getTrace (); // backtrace () array
Final function getTraceAsString (); // getTrace () information formatted as a string
}
?>
Correspondingly, you can call getFile () and getLine () in the code to locate the error, making debugging easier.
Use process-oriented methods
First look at the code:
The code is as follows:
$ Db = new PDO ('MySQL: host = localhost; dbname = test', $ user, $ pass );
$ Rs = $ db-> query ("SELECT aa, bb, cc FROM foo ");
If ($ db-> errorCode ()! = '000000 '){
Print_r ($ db-> errorInfo ());
Exit;
}
$ Arr = $ rs-> fetchAll ();
Print_r ($ arr );
$ Db = null;
?>
The PDO and PDOStatement objects have the errorCode () and errorInfo () methods. if there are no errors, errorCode () returns: 00000. otherwise, some error codes are returned. An array returned by errorInfo (), including the PHP-defined error code and MySQL error code and error information. the array structure is as follows:
Array
(
[0] => 42S22
[1] => 1054.
[2] => Unknown column 'AAA' in 'Field list'
)
After each query, the results of errorCode () are the latest, so we can easily control the display of error information.
What should I do if I encounter another error when I use PDO for PHP and database development? Follow the above steps.
11.3.4 PDO error handling
PDO provides two methods to get the error information in the program. one is the errorCode () method, and the other is the errorInfo () method.
1. errorCode () method
The errorCode () method is used to obtain the error code generated when operating the database handle. these error codes are called SQLSTATE codes. the syntax format of this method is as follows:
01 the return value of the string errorCode (void) errorCode () method is a SQLSTATE, which consists of five digits and letters. The following is an example of using the errorCode () method:
[Program 11-17] CD \ code \ 11 \ pdo \ errorCode. php
The code is as follows:
$ Dsn = 'MySQL: dbname = shop; host = localhost ';
$ User_name = 'root ';
$ User_psw = 'root ';
$ Pdo = new PDO ($ dsn, $ user_name, $ user_psw );
$ Pdo-> exec ("update mytable set age = 28 where id = 1"); // The Table mytable does not exist.
Echo "errorCode:". $ pdo-> errorCode ();
?>
The error code output from the above code is 11-13.
2. errorInfo () method
The errorInfo () method is used to obtain the error information generated when operating the database handle. the syntax format of this method is as follows:
01 the returned value of the array errorInfo (void) errorInfo () method is an array containing error information. the sample code for using the errorInfo () method is as follows:
[Program 11-18] CD \ code \ 11 \ pdo \ errorInfo. php
The code is as follows:
$ Dsn = 'MySQL: dbname = shop; host = localhost ';
$ User_name = 'root ';
$ User_psw = 'root ';
$ Pdo = new PDO ($ dsn, $ user_name, $ user_psw );
$ Pdo-> exec ("update mytable set age = 28 where id = 1"); // The Table mytable does not exist.
Echo "errorInfo :";
Print_r ($ pdo-> errorInfo ());
?>
The error message output from the above code is 11-14.
First, let's take a look at the handling of connection errors and PDO errors in PHP, and use the object-oriented method to handle them: the code is as follows :? Php try {$ db = new PD...