事务可确保数据库操作的原子性与一致性,PHP中通过PDO的beginTransaction()开启事务,执行SQL后若全部成功则commit()提交,任一步失败则rollback()回滚,如银行转账实例所示。

在PHP中操作数据库时,使用事务可以确保一组SQL操作要么全部成功,要么全部失败。这在银行转账这类对数据一致性要求极高的场景中非常关键。下面通过一个具体的银行账户转账实例来说明如何在PHP中使用数据库事务。
事务是一组数据库操作的集合,具有ACID特性(原子性、一致性、隔离性、持久性)。这意味着:
使用PDO进行数据库操作时,开启事务的流程如下:
立即学习“PHP免费学习笔记(深入)”;
假设我们有两个用户账户表 accounts,包含字段 id、name、balance(余额)。
本书全面介绍PHP脚本语言和MySOL数据库这两种目前最流行的开源软件,主要包括PHP和MySQL基本概念、PHP扩展与应用库、日期和时间功能、PHP数据对象扩展、PHP的mysqli扩展、MySQL 5的存储例程、解发器和视图等。本书帮助读者学习PHP编程语言和MySQL数据库服务器的最佳实践,了解如何创建数据库驱动的动态Web应用程序。
385
<?php
$host = 'localhost';
$db = 'test_db';
$user = 'root';
$pass = '';
$charset = 'utf8mb4';
<p>$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false,
];</p><p>try {
$pdo = new PDO($dsn, $user, $pass, $options);</p><pre class='brush:php;toolbar:false;'>// 开始事务
$pdo->beginTransaction();
// 转出账户减钱(例如:用户A转出100元)
$sql1 = "UPDATE accounts SET balance = balance - 100 WHERE id = 1";
$stmt1 = $pdo->prepare($sql1);
$stmt1->execute();
// 检查是否更新成功
if ($stmt1->rowCount() == 0) {
throw new Exception("转出账户操作失败,账户可能不存在");
}
// 转入账户加钱(用户B收到100元)
$sql2 = "UPDATE accounts SET balance = balance + 100 WHERE id = 2";
$stmt2 = $pdo->prepare($sql2);
$stmt2->execute();
if ($stmt2->rowCount() == 0) {
throw new Exception("转入账户操作失败,账户可能不存在");
}
// 检查转入账户余额是否正常(可选校验)
$checkSql = "SELECT balance FROM accounts WHERE id = 2";
$checkStmt = $pdo->query($checkSql);
$result = $checkStmt->fetch();
if ($result['balance'] < 0) {
throw new Exception("目标账户余额异常");
}
// 所有操作成功,提交事务
$pdo->commit();
echo "转账成功!";} catch (Exception $e) { // 出现异常,回滚事务 $pdo-youjiankuohaophpcnrollback(); echo "转账失败:" . $e->getMessage(); }
在实际开发中需要注意以下几点:
基本上就这些。只要合理使用事务,就能有效保证像银行转账这种关键业务的数据安全和一致性。
以上就是php数据库如何使用事务 php数据库银行转账操作的实例的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号