首页 > 代码库 > PDO中的事务处理

PDO中的事务处理

基本原理和步骤其实都是一样的(可参看上一篇“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中使用事务原理基本一样!

PDO中的事务处理