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>
|