文档章节

PHP PDO事务回滚

kongjun
 kongjun
发布于 2015/06/04 15:09
字数 220
阅读 82
收藏 1
<?php
    try{
        $pdo=new pdo("mysql:host=localhost;dbname=xsphpdb", "root", "123456", array(PDO::ATTR_AUTOCOMMIT=>0));//最后是关闭自动提交
        //$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 0);//这个是通过设置属性方法进行关闭自动提交和上面的功能一样
        $pdo->setAttribute(PDO::ATTR_ERRMODE,  PDO::ERRMODE_EXCEPTION);//开启异常处理
    }catch(PDOException $e){
        echo "数据库连接失败:".$e->getMessage();
        exit;
    }
    /*
     * 事务处理
     *
     */
    try{
        $pdo->beginTransaction();//开启事务处理       
        $price=500;
        $sql="update zhanghao set price=price-{$price} where id=1";
        $affected_rows=$pdo->exec($sql);
        if(!$affected_rows)
            throw new PDOException("张三转出失败");//那个错误抛出异常
        $sql="update zhanghao set price=price+{$price} where id=3";
        $affected_rows=$pdo->exec($sql);      
        if(!$affected_rows)
            throw new PDOException("向李四转入失败");
        echo "交易成功!";
        $pdo->commit();//交易成功就提交
    }catch(PDOException $e){
        echo $e->getMessage();
        $pdo->rollback();
    }  
    $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT, 1);//自动提交,如果最后不自动提交,转账是不成功的  
    //设置错误报告模式 ERRMODE_SILENT    ERRMODE_WARNING


© 著作权归作者所有

共有 人打赏支持
kongjun
粉丝 7
博文 98
码字总数 40811
作品 0
杭州
程序员
数据库抽象层 PDO

数据库抽象层 PDO 链接与链接管理 如果有任何连接错误,将抛出一个 异常对象。如果想处理错误状态,可以捕获异常,或者选择留给通过 设置的应用程序全局异常处理程序。 事务与自动提交 事务支...

liangwt
2016/08/28
8
0
PDO 完全使用教程

一.PDO异常处理 PDO::ATTR_ERRMODE 1) PDO::ATTR_ERRMODE//不报错误(忽略)(0) 2) PDO::ERRMODE_WARNING //以警告的方式报错(1) 3) PDO::ERRMODE_EXCEPTION //以异常的方式报错(2) 二.PDO预处...

myzyq
2016/03/14
35
0
PHP中实现MySQL嵌套事务的两种解决方案

一、问题起源 在MySQL的官方文档中有明确的说明不支持嵌套事务: [sql] view plaincopy Transactions cannot be nested. This is a consequence of the implicit commit performed for any c......

开元中国2015
2015/04/23
57
0
PDO

PDO 一、什么是PDO PDO是PHP数据对象(PHP Data Object)的缩写 二、怎么查看php是否支持PDO 1. 使用phpinfo() 函数查看PDO是否支持 2. 如果没有开启PDO 请查看 wamp目录:(C:wampbinphpphp7.0....

方花
2017/11/21
0
0
阅读杂记(RSA,PDO)

RSA算法 RSA Key Size Selection http://www.vocal.com/cryptography/rsa-key-size-selection/ 这篇文章说的是如何选择RSA密钥的长度。RSA密钥的长度是可以选择的,RSA密钥的长度影响加密后的...

王二狗子11
01/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

sed命令

10月17日任务 9.4/9.5 sed 1.sed(上)(下) 1.sed 匹配功能 #sed -n ‘/root/’ p test.txt 将带有root的内容打印出来 同时支持 . * 还有 + 不过需要脱译,或者在前面选项加r。 支持{ } 支...

hhpuppy
33分钟前
1
0
day120-20181018-英语流利阅读-待学习

千禧一代注意了:一大波公司正向你的钱包袭来 Daniel 2018-10-18 1.今日导读 这几年,你有没有发现,不管是在微信公众号还是在抖音,有越来越多的商家和品牌开始玩起了网络用语和表情包,从卖...

飞鱼说编程
42分钟前
1
0
IOasd

能够使用FileUtils常用方法操作文件 字符流体系介绍 : 在 IO 开发中, 我们传输最频繁的数据为字符, 而以字节的方式来传输字符数据会使程序员丧失对数据内容的判断.因为程序员只认识字符, 不认...

码农屌丝
今天
0
0
创建第一个react项目

sudo npm i -g create-react-app@1.5.2 create-react-app react-app cd react-apprm -rf package-lock.jsonrm -rf node_modules #主要是为了避免报错npm installnpm start......

lilugirl
今天
3
0
在浏览器中进行深度学习:TensorFlow.js (八)生成对抗网络 (GAN)

Generative Adversarial Network 是深度学习中非常有趣的一种方法。GAN最早源自Ian Goodfellow的这篇论文。LeCun对GAN给出了极高的评价: “There are many interesting recent development...

naughty
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部