PDO的事物处理机制

Mysql的事务处理:

    1.MySQL目前只有InnoDB 和BDB两个数据表类型才支持事务。

  2.在默认条件下,MySQL是以自动提交(autocommit)模式运行的,这就意味着所执行的每一个语句都将立即写入数据库中。但是事务中是不希望有自动提交的行为的。set autocommit = 0; //在当前的会话中关闭自动提交。

 3.start transaction;//开始一个事务;

 4.commit ; //提交一个事务

 5.roolback ; //事务回滚,所有的操作都将被取消。

使用PDO编程的实例如下:

<?php
/*
 * 
 * @Authors peng--jun 
 * @Email   1098325951@qq.com
 * @Date    2016-01-22 14:12:03
 * @Link    http://www.cnblogs.com/xs-yqz/
 * @version $Id$
 ==========================================
 */
 header("Content-type: text/html; charset=UTF-8"); 
 
$pdo = new PDO("mysql:host=localhost;dbname=test","root","jun");
$pdo -> setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$pdo -> setAttribute(PDO::ATTR_AUTOCOMMIT,0);

try {
    $price = 80;
    $pdo -> beginTransaction();
    $sql = "update account set cash = cash-{$price} where name = 'UserA'";
    $affected_rows = $pdo -> exec($sql);
    if ($affected_rows>0) {
        echo "userA 成功转出{$price}元人民币<br />";
    } else {
        throw new PDOException("UserA 转出失败".$sql);
    }

    $sqlB = "update account set cash = cash+{$price} where name = 'UserB'";
    $affected_rows = $pdo -> exec($sqlB);
    if ($affected_rows>0) {
        echo "成功向userB转入{$price}元人民币";
    } else {
        throw new PDOException("UserB 转入失败");
    }

    echo "交易成功!!!";
    $pdo -> commit();
} catch (PDOException $e) {
    echo "交易失败".$e -> getMessage();
    $pdo -> rollback();
}

$pdo -> setAttribute(PDO::ATTR_AUTOCOMMIT,1);
?>

 

转载于:https://www.cnblogs.com/xs-yqz/p/5151237.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值