18.5.3  PDO的错误处理模式

PDO共提供了3种不同的错误处理模式,不仅可以满足不同风格的编程,也可以调整扩展处理错误的方式。

1.PDO::ERRMODE_SILENT

这是默认模式,在错误发生时不进行任何操作,PDO将只设置错误代码。开发人员可以通过PDO对象中的errorCode()和errorInfo()方法对语句和数据库对象进行检查。如果错误是由于对语句对象的调用而产生的,那么可以在相应的语句对象上调用errorCode()或errorInfo()方法。如果错误是由于调用数据库对象而产生的,那么可以在相应的数据库对象上调用上述两种方法。

2.PDO::ERRMODE_WARNING

除了设置错误代码,PDO还将发出一条PHP传统的E_WARNING消息,可以使用常规的PHP错误处理程序捕获该警告。如果只想看看发生了什么问题,而无意中断应用程序的流程,那么在调试或测试中这种设置很有用。该模式的设置方式如下:

$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING); //设置警告模式处理错误报告

3.PDO::ERRMODE_EXCEPTION

除了设置错误代码,PDO还会抛出一个PDOException并设置其属性,以反映错误代码和错误信息。这种设置在调试中也很有用,因为它会放大脚本中产生错误的地方,从而非常快速地指出代码存在潜在问题的区域(记住,如果异常导致脚本终止,则事务将自动回滚)。异常模式的另一个有用的地方是,与传统的PHP风格的警告相比,可以更清晰地构造自己的错误处理;而且,比起以静寂方式及显式地检查每个数据库调用的返回值的模式,异常模式需要的代码及嵌套代码也更少。该模式的设置方法如下:

$dbh->setAttribute(PDO::ATTR_ERRMODE,   PDO::ERRMODE_EXCEPTION); //设置抛出异常模式处理错误

SQL标准提供了一组用于指示SQL查询结果的诊断代码,称为SQLSTATE代码。PDO制定了使用SQL-92 SQLSTATE错误代码字符串的标准,不同PDO驱动程序负责将它们的本地代码映射为适当的SQLSTATE代码。例如,可以在MySQL安装目录下的include/sql_state.h文件中找到MySQL的SQLSTATE代码列表。可以使用PDO对象或PDOStatement对象中的errorCode()方法返回一个SQLSTATE代码。如果需要关于一个错误的更多特定的信息,在这两个对象中还提供了一个errorInfo()方法,该方法将返回一个数组,其中包含SQLSTATE代码、特定于驱动程序的错误代码,以及特定于驱动程序的错误字符串。

18.5.4  使用PDO执行SQL语句

在使用PDO执行查询数据之前,先提供一组相关的数据。创建PDO对象并通过MySQL驱动连接localhost的MySQL数据库服务器,MySQL服务器的登录名为“MySQL_user”,密码为“MySQL_pwd”。创建一个以“testdb”命名的数据库,并在该数据库中创建一个联系人信息表contactInfo。建立数据表的SQL语句如下所示:

CREATE TABLE contactInfo (                                           #创建表contactInfo

uid   mediumint(8) unsigned NOT NULL AUTO_INCREMENT,             #联系人ID

name   varchar(50) NOT NULL,                                       #姓名

departmentId   char(3) NOT NULL,                                      #部门编号

address   varchar(80) NOT NULL,                                     #联系地址

phone   varchar(20),                                                #联系电话

email   varchar(100),                                                 #联系人的电子邮件

PRIMARY   KEY(uid)                                              #设置用户ID为主键

);

数据表contactInfo建立后,向表中插入多行记录。本例中插入的数据如表18-4所示。

表18-4  实例演示中插入的数据记录

在PHP脚本中,通过PDO执行SQL查询与数据库进行交互,可以分3种不同的策略,使用哪种方法取决于要执行什么操作。

1.使用PDO::exec()方法

当执行INSERT、UPDATE和DELETE等没有结果集的查询时,使用PDO对象中的exec()方法。该方法成功执行后,将返回受影响的行数。注意,该方法不能用于SELECT查询,代码如下所示:

2.使用PDO::query()方法

当执行返回结果集的SELECT查询,或者所影响的行数无关紧要时,应当使用PDO对象中的query()方法。如果该方法成功执行指定的查询,则返回一个PDOStatement对象。如果使用了query()方法,并想了解获取的数据行总数,可以使用PDOStatement对象中的rowCount()方法,代码如下所示:

根据前面给出的数据样本,输出以下3条符合条件的数据记录:

一共从表中获取到3条记录:

高某某       15801680168      gmm@lampbrother.net

王某某       15801681357      wmm@lampbrother.net

陈某某       15801682468      cmm@lampbrother.net

另外,可以使用PDO过滤一些特殊字符,以防止一些能引起SQL注入的代码混入。我们在PDO中使用quote()方法实现,示例如下:

$query = "SELECT * FROM users WHERE   login=".$dbh->quote($_POST['login'])."   AND passwd=".$db->   quote($_POST['pass']);

3.使用PDO::prepare()和PDOStatement::execute()两个方法

当同一个查询需要多次执行时(有时需要迭代传入不同的列值),使用预处理语句的方式来实现,效率会更高。从MySQL 4.1开始,就可以结合MySQL使用PDO对预处理语句的支持。使用预处理语句需要用PDO对象中的prepare()方法去准备一个将要执行的查询,再用PDOStatement对象中的execute()方法来执行。

《细说PHP》第四版 样章 第18章 数据库抽象层PDO 6的更多相关文章

  1. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 1

    现在,如果你已经能熟练地使用MySQL客户端软件来操作数据库中的数据,就可以开始学习如何使用PHP来显示和修改数据库中的数据了.PHP提供了标准的函数来操作数据库.在PHP 5以上的版本中可以使用My ...

  2. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 12

    18.9  管理表books实例 在Web项目中,几乎所有模块都要和数据表打交道,而对表的管理无非就是增.删.改.查等操作,所以熟练掌握对表进行管理的这些常见操作是十分有必的.本例为了能更好地展示PD ...

  3. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 11

    18.8.3  完美分页类的代码实现 分页类的编写除了需要使用在18.8.2节中提供的可以操作的3个成员方法,还需要更多的成员,但其他的成员方法和成员属性只需要内部使用,并不需要用户在对象外部操作,所 ...

  4. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 7

    18.6  PDO对预处理语句的支持 在生成网页时,许多PHP脚本通常都会执行除参数外其他部分完全相同的查询语句.针对这种重复执行一个查询,但每次迭代使用不同参数的情况,PDO提供了一种名为预处理语句 ...

  5. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 4

    18.4  创建PDO对象 使用PDO在与不同数据库管理系统之间交互时,PDO对象中的成员的方法是统一各种数据库的访问接口,所以在使用PDO与数据库交互之前,首先要创建一个PDO对象.在通过构造方法创 ...

  6. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 10

    18.8  设计完美分页类 数据记录列表几乎出现在Web项目的每个模块中,假设一张表中有十几万条记录,我们不可能一次全都显示出来,当然也不能仅显示几十条.为了解决这样的矛盾,通常在读取时设置以分页的形 ...

  7. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 9

    18.7  PDO的事务处理 事务是确保数据库一致的机制,是一个或一系列的查询,作为一个单元的一组有序的数据库操作.如果组中的所有SQL语句都操作成功,则认为事务成功,那么事务被提交,其修改将作用于所 ...

  8. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 8-1

    18.6.5  获取数据 PDO的数据获取方法与其他数据库扩展非常类似,只要成功执行SELECT查询,都会有结果集对象生成.不管使用PDO对象中的query()方法,还是使用prepare()和exe ...

  9. 《细说PHP》第四版 样章 第18章 数据库抽象层PDO 8

    18.6.4  执行准备好的查询 当准备好查询并绑定了相应的参数后,就可以通过调用PDOStatement类对象中的execute()方法,反复执行在数据库缓存区准备好的语句了.在下面的示例中,向前面 ...

随机推荐

  1. win10 安装cuda和cudnn

    首先通过nvidia-smi 查看自己的显卡驱动对应的cuda版本. 参考:https://blog.csdn.net/qq_40212975/article/details/89963016 再去官 ...

  2. 将vue项目部署在Linux的Nginx下,并设置为局域网内访问

    1. 下载 wget http://nginx.org/download/nginx-1.12.2.tar.gz 2. 解压缩 tar -zxvf linux-nginx-1.12.2.tar.gz ...

  3. 【algo&ds】4.B树、字典树、红黑树、跳表

    上一节内容[algo&ds]4.树和二叉树.完全二叉树.满二叉树.二叉查找树.平衡二叉树.堆.哈夫曼树.散列表 7.B树 B树的应用可以参考另外一篇文章 8.字典树Trie Trie 树,也叫 ...

  4. HBuildX报错此插件的使用依赖于外部应用程序eslint,本机未检测到此应用

    最近刚刚开始用HBuildX,结果保存时报错 解决方案: 打开HBuilderX 打开plugins 打开eslint-vue, 然后Git Bash Here,npm install 重新安装一下 ...

  5. Python【day 18】面向对象-类和类的关系

    一.昨日内容回顾 成员 1.变量 1.成员变量--最常见 1.写法: 变量前面加了self就是成员变量 这里的self表示当前对象 一般是在构造方法中定义 2.调用: 对象.成员变量 3.作用: 可以 ...

  6. JAVA学习第二步,初级知识框架梳理

    回顾往期的学习,才发现已经学习了这么多知识点.这里复制了其他创作者的一些梳理结合自己的梳理.总结了自己在Java学习入门阶段的知识点.笔记自己了也写了详细的两本 第一章 Java面向对象 1-1包的定 ...

  7. Vue组件化开发

    Vue的组件化 组件化是Vue的精髓,Vue就是由一个一个的组件构成的.Vue的组件化设计到的内容又非常多,当在面试时,被问到:谈一下你对Vue组件化的理解.这时候又有可能无从下手,因此在这里阐释一下 ...

  8. js分号问题

    总结一句话: 一行开头是括号(比如IIFE)或者方括号的时候加上分号就可以

  9. 77777 77777(2) WriteUp 绕waf技巧学习

    两个题的代码都是一样的 只是waf不一样 贴出代码 <?php function update_point($p,$point){ global $link; $q = sprintf(&quo ...

  10. Java中如何判断一个字符是否是字母或数字

    使用Java中Character类的静态方法: Character.isDigit(char c) //判断字符c是否是数字字符,如‘1’,‘2’,是则返回true,否则返回false   Chara ...