《PHP精粹:编写高效PHP代码》——2.6节处理PDO中的错误

简介:

本节书摘来自华章社区《PHP精粹:编写高效PHP代码》一书中的第2章,第2.6节处理PDO中的错误,作者:(美)  Davey Shafik,更多章节内容可以访问云栖社区“华章社区”公众号查看

2.5 处理PDO中的错误
当你刚开始使用PDO时,它的某个方面是令人惊讶或让人沮丧的(视你的态度而定),即当它出现问题时,并不总是显而易见的。当我们第一次连接到数据库时,就会看到一个失败的连接会导致抛出一个异常。这里有一个提醒的代码:


6b8f43a4205ceb3639004bf3deb912811267e5f6

一般来说,当某些引人注目的事情发生时PDO会抛出异常,但是如果你的查询由于某些原因而未能运行时,你也不必为此大惊小怪。这表明我们要仔细检查一切是否按照我们所预期的那样运行。
让我们复习一下迄今为止所学到的相关内容,看看我们如何对出现的问题进行识别和反应。

2.5.1 处理预处理时的问题
当我们调用PDO::prepare()方法时,这个函数会为我们返回一个PDOStatement对象。我们知道,如果这个预处理失败,该函数可能会返回false或抛出一个PDOException,因此,我们应该像这样包裹代码:


189f6cf68d72eecd3690aa841e84a5367b9d7311

上述示例中的prepare()调用返回了false。此外,如果一个异常发生在我们预处理过程的任何阶段,无论是执行还是获取,它将马上被捕捉并得到处理。
这个示例使用了getMessage()方法,它会告诉你抛出异常的原因。更多关于使用异常的知识可以回顾第1章中的相关内容。

2.5.2 处理执行时的问题
一旦我们有了PDOStatement,就可以绑定任何我们需要的值或参数,并且可以执行它。如果execute()方法成功会返回true;如果失败则返回false,这是我们尝试提取任何结果前检查一切是否正确的最好办法。
一个典型的示例如下所示:


a108e35a100a7451c7540a92d5baa62889780e7c


a3ca8c9fab53d8e2784138807bdfdcfc3cdb7f9d

注意,我们指定了execute()调用的结果,因此可以检查这个结果是true还是false。如果它是true,我们可以继续提取数据,或者接着做想做的任何事情。
然而,如果execute()方法失败了,PDO不会给我们任何解释!相反,我们必须使用errorInfo()方法主动找到错误产生的原因。它会返回一个由3个元素组成的数组:
1)SQLSTATE—一个关于错误产生原因的ANSI SQL标准码;
2)来自数据库驱动的错误代码;
3)来自数据库驱动的错误消息。
在这个示例中,我们使用了第三个元素:错误消息。如果你使用命令行、phpMyAdmin或任何类似的工具针对数据库手动运行这个查询,你将会看到这个错误。当然,在开发阶段这是对我们最有用的信息了。

2.5.3 处理提取数据时的问题
如果我们成功地调用了execute()方法,那么说明已经战胜了大部分的挑战。但是如果我们调用fetch()方法时出了差错,这个方法将返回false。你可以选择在数据库代码中捕捉并测试返回值是否为最佳选择,或者应用程序是否会处理false被返回的情况。像以前一样,我们用PDOStatement::errorInfo()方法返回数组中关于错误的有用信息。
fetch()方法也可以返回一个空数组(或等效的其他方式,这取决于你的提取模式,就像我们在2.4.3节中看到的一样),并且没有错误状态。这个空数组仅仅表明没有符合你查询的记录。

相关文章
|
12月前
|
消息中间件 缓存 弹性计算
纯PHP+MySQL手搓高性能论坛系统!代码精简,拒绝臃肿
本内容分享了一套经实战验证的社交系统架构设计,支撑从1到100万用户的发展,并历经6次流量洪峰考验。架构涵盖客户端层(App、小程序、公众号)、接入层(API网关、负载均衡、CDN)、业务服务层(用户、内容、关系、消息等服务)、数据层(MySQL、Redis、MongoDB等)及运维监控层(日志、监控、告警)。核心设计包括数据库分库分表、多级缓存体系、消息队列削峰填谷、CQRS模式与热点数据动态缓存。同时提供应对流量洪峰的弹性伸缩方案及降级熔断机制,并通过Prometheus实现全链路监控。开源建议结构清晰,适合大型社交平台构建与优化。
433 11
|
9月前
|
存储 缓存 安全
php项目源码加密之Zend Guard Loader加密的代码解密可能性很小-优雅草卓伊凡
php项目源码加密之Zend Guard Loader加密的代码解密可能性很小-优雅草卓伊凡
396 2
|
IDE PHP 开发工具
PHP中的类型提示与严格模式:提高代码可维护性
随着PHP语言的发展,开发者对代码的可读性、可维护性和可靠性有了更高的要求。PHP中的类型提示(Type Hinting)和严格模式(Strict Mode)为开发者提供了更强的类型检查机制,有助于提升代码质量和减少潜在的错误,尤其是在大型项目中。
|
安全 程序员 PHP
PHP中的异常处理:提升代码的健壮性
【10月更文挑战第8天】在编程的世界中,错误和异常是不可避免的。它们就像路上的坑洼,可能会让我们的程序“跌倒”。但是,如果我们能够正确地处理这些异常,就可以让我们的程序更加稳健,就像我们学会了如何在坑洼的路上稳稳地行走一样。本文将介绍PHP中的异常处理机制,以及如何使用它来提升我们的代码质量。
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
228 20
|
供应链 安全 NoSQL
PHP 互斥锁:如何确保代码的线程安全?
在多线程和高并发环境中,确保代码段互斥执行至关重要。本文介绍了 PHP 互斥锁库 `wise-locksmith`,它提供多种锁机制(如文件锁、分布式锁等),有效解决线程安全问题,特别适用于电商平台库存管理等场景。通过 Composer 安装后,开发者可以利用该库确保在高并发下数据的一致性和安全性。
254 6
|
PHP 开发者 UED
探索PHP中的异常处理:提升代码的健壮性
在PHP开发中,优雅地处理错误和异常是确保应用稳定性和用户体验的关键。本文将通过深入浅出的方式,介绍如何在PHP中实现有效的异常处理机制,包括异常的基本概念、如何抛出和捕获异常,以及最佳实践。准备好让你的代码变得更加健壮和可靠吧!
191 2
|
SQL PHP 数据库
19 PHP如何利用PDO获取结果集
路老师在知乎上分享了关于PHP语言的知识,帮助大家入门并深入了解PHP。本文介绍了PDO中获取结果集的三种方法:`fetch()`、`fetchAll()` 和 `fetchColumn()`,并通过具体案例展示了如何使用这些方法从数据库中获取数据并展示在网页上。
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性和扩展性
【10月更文挑战第13天】 本文将探讨PHP中常见的设计模式及其在实际项目中的应用。通过对比传统编程方式,我们将展示设计模式如何有效地提高代码的可维护性和扩展性。无论是单例模式确保类的单一实例,还是观察者模式实现对象间的松耦合,每一种设计模式都为开发者提供了解决特定问题的最佳实践。阅读本文后,读者将能更好地理解和应用这些设计模式,从而提升PHP编程的效率和质量。
|
PHP 开发者
PHP中的异常处理:提升代码的健壮性
【10月更文挑战第40天】在PHP编程中,异常处理是确保应用稳定性的关键。本文将引导你理解异常处理的重要性,掌握如何在PHP中捕获和处理异常,以及如何通过自定义异常类来增强代码的错误管理能力。我们将一起探索如何利用PHP的异常处理机制,打造一个更加健壮和可靠的应用程序。
156 0