PDO的事务处理 事务回滚

<?php
header('content-type:text/html;charset=utf-8');
include 'PdoClass.php';
$objPdo=new PdoClass();
//事务
try{
$dsn = "mysql:host=localhost;dbname=xxx";
$username = "root";
$password = 'root';
$pdo = new PDO($dsn, $username, $password,array(PDO::ATTR_AUTOCOMMIT=>0,PDO::ATTR_DEFAULT_FETCH_MODE=> PDO::FETCH_ASSOC,PDO::ATTR_CASE=>PDO::CASE_LOWER)) ;
$pdo->exec('set names utf8');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}catch(PDOException $e){
echo "connect fail:".$e->getMessage();
exit;
}
try{
$pdo->beginTransaction();
$price = 500;
$list=$objPdo->getAll('user');
$goods = $objPdo->getAll('goods');
//print_r($goods);die;
$res=$list[0]['money'];
$goods_count=$goods[0]['g_count'];
if($res<500){
throw new PDOException('从A帐号中扣出失败');
}else if($goods_count==0){
throw new PDOException('从商品表中扣出失败');
}else {
$sql = "update user set money=money-{$price} where u_id=1";
$pdo->exec($sql);
$sql1 = "update user set money=money+{$price} where u_id=2";
$pdo->exec($sql1);
$sql2 = "update goods set g_count=g_count-1 where g_id=1";
$pdo->exec($sql2);
}
$pdo->commit();
} catch (PDOException $ex) {
$pdo->rollBack();
$title = isset($_POST['title'])?$_POST['title']:'';
$list = $objPdo->getAll('user',$title);
$goods = $objPdo->getAll('goods',$title);
include 'form.html';
echo $ex->getMessage();
}

?>

转载于:https://www.cnblogs.com/sdfgdrg/p/9994509.html

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值