《PHP精粹:编写高效PHP代码》——2.6节高级PDO特征

简介:

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

2.6 高级PDO特征
我们已经看到PDO功能构成了以数据库驱动的PHP应用程序的主体。然而, PDO还有几个锦囊妙计需要我们好好研究。下面两节将显示我们如何利用数据库的事务,以及如何在PHP代码中调用存储过程。

2.6.1 事务和PDO
在数据库术语中事务(transaction)是一组必须执行的语句的集合。这组语句要么必须全部顺利完成,要么一个也不运行。不是所有的数据库都支持事务,有些支持,有些不支持,有些经过配置以后才会支持。对于MySQL,有些表的类型难以获得事务支持。
如果数据库不支持事务,PDO会假装事务正在顺利执行,因此在这种情形下要提防发生意想不到的结果。
若要使用事务,我们并不需要对代码做太多改变。如果有一系列的SQL语句要组成一个事务,我们只需要:
1)在运行任何语句之前通过调用PDO::beginTransaction()方法启动事务。
2)当所有的语句成功运行之后调用PDO::commit()方法。
3)如果调用PDO::rollback()方法时出现错误,我们要取消事务;这将取消所有已经运行的语句。
那么这些在代码中的表现又会是怎样呢?


892deee646a18c4b3244dab25db047dda5d0f8c8

你可以在任何地方使用回滚功能。例如,如果没有行被更新你可能想要回滚。何时使用这些功能完全取决于你建立的应用程序。
exec()方法和返回值
上面的示例中使用exec()方法对数据库运行了一次性语句。exec()的返回值若不是受影响的行数,就是查询失败时的false。当你使用===比较运算符检查返回值时,确定结果是否为false,并识别false返回值和零影响行之间的区别时,你要特别小心。

事务在关键信息应用程序中特别有用,传统上,我们将它们用在如银行这样的领域。如果有一笔钱从一个账户取出,就必须进入另一个账户,或者依然保留在第一个账户中!事务使这种系统在可靠和故障安全的方式中运行。我们使用事务功能,比起费力分析在发生错误的事件里我们应该运行哪种查询更为简单。

2.6.2 存储过程和PDO
一些数据库平台还支持存储过程(stored procedure),它类似于函数,但存储在数据库层。数据库平台在调用它们的时候可以选择一些参数,如同之前所做,我们在预处理语句中使用占位符。为了说明这个例子,让我们来创建一个简单的存储过程:


8338d989a2b1d5ab731d8ae9d1ae1978042dfcc2

存储过程实际上是一个相当大的主题;如果你想更多地了解它们,你可以看一下PHP手册中关于存储过程的部分。如果你需要,存储过程是在数据库层中包含应用程序逻辑的非常有用的方式。

相关文章
|
1月前
|
IDE PHP 开发工具
PHP中的类型提示与严格模式:提高代码可维护性
随着PHP语言的发展,开发者对代码的可读性、可维护性和可靠性有了更高的要求。PHP中的类型提示(Type Hinting)和严格模式(Strict Mode)为开发者提供了更强的类型检查机制,有助于提升代码质量和减少潜在的错误,尤其是在大型项目中。
|
2月前
|
安全 程序员 PHP
PHP中的异常处理:提升代码的健壮性
【10月更文挑战第8天】在编程的世界中,错误和异常是不可避免的。它们就像路上的坑洼,可能会让我们的程序“跌倒”。但是,如果我们能够正确地处理这些异常,就可以让我们的程序更加稳健,就像我们学会了如何在坑洼的路上稳稳地行走一样。本文将介绍PHP中的异常处理机制,以及如何使用它来提升我们的代码质量。
|
9天前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
13 1
|
15天前
|
供应链 安全 NoSQL
PHP 互斥锁:如何确保代码的线程安全?
在多线程和高并发环境中,确保代码段互斥执行至关重要。本文介绍了 PHP 互斥锁库 `wise-locksmith`,它提供多种锁机制(如文件锁、分布式锁等),有效解决线程安全问题,特别适用于电商平台库存管理等场景。通过 Composer 安装后,开发者可以利用该库确保在高并发下数据的一致性和安全性。
30 6
|
12天前
|
PHP 开发者 UED
探索PHP中的异常处理:提升代码的健壮性
在PHP开发中,优雅地处理错误和异常是确保应用稳定性和用户体验的关键。本文将通过深入浅出的方式,介绍如何在PHP中实现有效的异常处理机制,包括异常的基本概念、如何抛出和捕获异常,以及最佳实践。准备好让你的代码变得更加健壮和可靠吧!
14 2
|
27天前
|
SQL PHP 数据库
19 PHP如何利用PDO获取结果集
路老师在知乎上分享了关于PHP语言的知识,帮助大家入门并深入了解PHP。本文介绍了PDO中获取结果集的三种方法:`fetch()`、`fetchAll()` 和 `fetchColumn()`,并通过具体案例展示了如何使用这些方法从数据库中获取数据并展示在网页上。
45 8
|
23天前
|
PHP 开发者
PHP中的异常处理:提升代码的健壮性
【10月更文挑战第40天】在PHP编程中,异常处理是确保应用稳定性的关键。本文将引导你理解异常处理的重要性,掌握如何在PHP中捕获和处理异常,以及如何通过自定义异常类来增强代码的错误管理能力。我们将一起探索如何利用PHP的异常处理机制,打造一个更加健壮和可靠的应用程序。
|
2月前
|
设计模式 算法 数据库连接
PHP中的设计模式:提高代码的可维护性和扩展性
【10月更文挑战第13天】 本文将探讨PHP中常见的设计模式及其在实际项目中的应用。通过对比传统编程方式,我们将展示设计模式如何有效地提高代码的可维护性和扩展性。无论是单例模式确保类的单一实例,还是观察者模式实现对象间的松耦合,每一种设计模式都为开发者提供了解决特定问题的最佳实践。阅读本文后,读者将能更好地理解和应用这些设计模式,从而提升PHP编程的效率和质量。
|
2月前
|
设计模式 SQL 安全
PHP中的设计模式:单例模式的深入探索与实践在PHP开发领域,设计模式是解决常见问题的高效方案集合。它们不是具体的代码,而是一种编码和设计经验的总结。单例模式作为设计模式中的一种,确保了一个类仅有一个实例,并提供一个全局访问点。本文将深入探讨单例模式的基本概念、实现方式及其在PHP中的应用。
单例模式在PHP中的应用广泛,尤其在处理数据库连接、日志记录等场景时,能显著提高资源利用率和执行效率。本文从单例模式的定义出发,详细解释了其在PHP中的不同实现方法,并探讨了使用单例模式的优势与注意事项。通过对示例代码的分析,读者将能够理解如何在PHP项目中有效应用单例模式。
|
2月前
|
程序员 数据库连接 PHP
PHP中的异常处理:提升代码的健壮性
【9月更文挑战第30天】在编程的世界里,错误和异常是不可避免的。本文将深入探索PHP中异常处理的机制,揭示如何通过有效的异常管理来增强代码的健壮性和可靠性。我们将从基础概念出发,逐步深入到高级应用,最后通过实际代码示例来巩固理论知识。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的指导和启示。
49 6