事务是一个很神奇的东西 什么叫做事务呢 就是同时可以执行多个语句 一旦有一个错误 就不能运行下去
例如我们需要做一些批量的操作并且同时执行 如果我们用其他方法 例如判断的话 那么就回一直判断 如果数据多的话 那么就有可能出错 所以我们要用一种简单的方式 开启事务 并且使用使用
简单的思路就是 开启事务 然后把要执行语句放在一起 如果一个出错那么任何都会不会往下走 并且锁定
代码如下
4.PDO事务处理
事务处理具有四个特性:原子性、一致性、独立性、持久性。
并不是所有的数据库都支持事务处理的,PDO 为能够执行事务处理的数据库提供事务支持。
配置事务处理需注意:
关闭 PDO 的自动提交;
$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, false);
开启一个事务需要的方法;
$pdo->beginTransaction(); // 开启一个事务
$pdo->commit(); // 提交事务
$pdo->rollback(); // 回滚事务
一般事务处理是运行在 try...catch...语句中,当事务失败时执行 catch 代码段。
<?php
try {
$pdo->beginTransaction(); // 开启一个事务
$row = null;
$row = $pdo->exec("xxx"); // 执行第一个 SQL
if (!$row)
throw new PDOException('提示信息或执行动作'); // 如出现异常提示信息或执行动作
$row = $pdo->exec("xxx"); // 执行第二个 SQL
if (!$row)
throw new PDOException('提示信息或执行动作');
$pdo->commit();
} catch (PDOException $e) {
$pdo->rollback(); // 执行失败,事务回滚
exit($e->getMessage());
}
?>
在事务中的 SQL 语句,如果出现错误,那么所有的 SQL 都不执行。当所有 SQL 有无误的时候,才提交执行。
这是开启事务的方式
还有一个例子
<?php
header("content-type:text/html;charset=utf-8");
$db = new mysqli("127.0.0.1","root","root","demo"); //连接数据库
$db->autocommit(false); //设置为非自动提交——事务处理
$sql1 = "update test set t_price=t_price-5 where t_name='小王'";
$result1 = $db->query($sql1);
$sql2 = "update test set t_price=t_price+2 where t_name='小明'";
$result2 = $db->query($sql2);
$sql3 = "update test set t_price=t_price+3 where t_name='小李'";
$result3 = $db->query($sql3);
if ($result1 && $result2 && $result3) {
$db->commit(); //全部成功,提交执行结果
echo '转账成功';
} else {
$db->rollback(); //有任何错误发生,回滚并取消执行结果
echo '回滚';
}
$db->autocommit(true); //设置为非自动提交——事务处理
$db->close();
?>
只供参考