PDOStatement::errorInfo — 获取跟上一次语句句柄操作相关的扩展错误信息(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0)!大理石机械构件维修厂家
在上一篇文章《PDO中错误处理的方法一-errorCode()方法》中我们介绍了PDO中错误处理的第一种方法,大家可以在上一篇文章回顾下,接下来我们为大家介绍PDO中错误处理的第二种方法~
errorInfo()方法用于获取操作数据库句柄时所发生的信息错误,该方法的语法格式如下:
1
|
array PDOStatement::errorInfo(void)
|
PDOStatement::errorInfo() 返回一个关于上一次语句句柄执行操作的错误信息的数组 。该数组包含下列字段:
元素 |
信息 |
0 |
SQLSTATE 错误码(一个由5个字母或数字组成的在 ANSI SQL 标准中定义的标识符)。 |
1 |
具体驱动错误码。 |
2 |
具体驱动错误信息。 |
在PDO中通过 query()方法完成数据的查询操作,并且通过 foreach 语句完成数据的循环输出,在定义SQL 语句的时候使用一个错误的数据表,并且通过errorInfo()方法返回错误信息,具体实现步骤如下:
创建一个php文件,首先通过PDO 连接MySQL数据库,然后通过query()方法执行查询语句,接着通过 errorInfo()方法获取错误信息,最后通过foreach 语句完成数据的循环输出,具体实现代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
<?php
header( "Content-Type:text/html; charset=utf-8" );
$dbms = "mysql" ;
$dbName = "php_cn" ;
$user = "root" ;
$pwd = "root" ;
$host = "localhost" ;
$dsn = "$dbms:host=$host;dbname=$dbName" ;
try {
$pdo = new PDO( $dsn , $user , $pwd );
$query = "select * from user_12" ;
$res = $pdo ->query( $query );
print_r( $pdo ->errorInfo());
?>
<table border= "1" width= "500" >
<tr>
<td height= "22" align= "center" valign= "middle" >id</td>
<td height= "22" align= "center" valign= "middle" >用户名</td>
<td height= "22" align= "center" valign= "middle" >密码</td>
</tr>
<?php
foreach ( $res as $items ){
?>
<tr>
<td height= "22" align= "center" valign= "middle" ><?php echo $items [ "id" ];?></td>
<td height= "22" align= "center" valign= "middle" ><?php echo $items [ "username" ];?></td>
<td height= "22" align= "center" valign= "middle" ><?php echo $items [ "password" ];?></td>
</tr>
<?php
}
} catch (PDOException $e ){
die ( "Error!:" . $e ->getMessage(). '<br>' );
}
?>
</table>
|