基本原理和步骤其实都是一样的(可参看上一篇“MySQL的事务处理”),PDO中的事务处理就是调用PDO对象的三个方法:
开启事务:beginTransaction
回滚操作:rollBack
执行操作:commit
事务处理最典型的就是借还钱。下面以张三向李四还1000元为例
首先看一下数据库中各自的钱数
下面是利用PDO处理还钱事务的代码:
<?php
/**
* 利用PDO对象实现事物操作
*/
echo "<meta charset=utf-8>";
//PDO类的实例化
// 1 设置数据源相关参数
$dbms = 'mysql'; //选择数据库类型
$host = 'localhost';
$port = '3306';
$dbname = 'test';
$charset = 'utf8';
$dsn = "$dbms:host=$host;port=$port;dbname=$dbname;charset=$charset";
// 2 设置用户名密码
$user = 'root';
$pwd = '';
// 3 实例化PDO类
$pdo = new PDO($dsn,$user,$pwd);
// 4 PDO事务物操作
// 4.1 开启事务
$pdo->beginTransaction();
//设置一个变量,用来判断所有sql语句是否成功
$flag = true;
// 4.2 执行事务中的一组sql语句
$sql = "update pdo set money=money+1000 where name='李四'";
$res = $pdo->exec($sql);
if (!$res) {
//如果sql语句执行失败,把$flag设置为false;
$flag=false;
}
$sql = "update pdo set money=money-1000 where name='张三'";
$res = $pdo->exec($sql);
if (!$res) {
//如果sql语句执行失败,把$flag设置为false;
$flag=false;
}
// 4.3 判断事务是否执行成功
if ($flag) {
//所有sql语句执行成功,把sql语句提交
$pdo->commit();
echo "还钱成功!";
}else{
// 如其中一条执行失败,则回滚到事务开启之前的状态
$pdo->rollback();
echo "还钱失败!";
}
结果:
下面,我们故意把其中一个字段写错,看看事务是否正常处理,数据库中的钱数是否有变化!
// 4.2 执行事务中的一组sql语句
$sql = "update pdo set mone = money+1000 where name='李四'"; //把moeny字段错写成mone
结果:
结果是还钱失败,并且数据库中各自的钱数没有变化,说明当某一条语句未执行成功时,事务不会提交,而会回滚,把数据恢复到开始事务之前的原始状态,这也是使用事务的作用,即只有当事务中所有sql语句全部执行成功,事务才会提交,否则会回滚!
PDO中使用事务和在MySQL中使用事务原理基本一样!