首页 > 后端开发 > php教程 > php中mysql事务回滚无效怎么办

php中mysql事务回滚无效怎么办

PHPz
发布: 2020-09-05 10:11:49
原创
1740 人浏览过

php中mysql事务回滚无效是因为数据库引擎设置为“MyISAM”了,该引擎是不支持事务回滚的,所以产生事务回滚无效,其解决办法就是将引擎更换为“InnoDB”即可恢复正常。

php中mysql事务回滚无效怎么办

php中mysql事务回滚无效怎么办?

我的测试环境:AppServ

<?php 
    header("Content-type:text/html;charset=utf-8");
    $pdo = new PDO(&#39;mysql:host=localhost;dbname=data&#39;,&#39;root&#39;,&#39;root&#39;);
    $pdo->exec(&#39;set names utf8&#39;);
    $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);#修改报错模式
  #开启事务
    $pdo->beginTransaction();
    try{
        #第一次操作
        $sql = &#39;delete from books where bId=40&#39;;
        $smt = $pdo->prepare($sql);
        $smt->execute();
        #第二次操作
        $sql = &#39;delete from1 books where bId=39&#39;;
        $smt = $pdo->prepare($sql);
        $smt->execute();
        #成功提交
        $pdo->commit();
    }catch(PDOException $e){
        echo $e->getMessage().&#39;<br>&#39;.$e->getLine();
        #失败撤回
        $pdo->rollBack();
    }
 ?>
登录后复制

如上:第二次操作出错的情况下 第一条操作没有被回滚

这时候赶紧去看看你的数据库引擎,你肯定看到是MyISAM,很不幸这个引擎不支持事务回滚。切换到 InnoDB 即可 。

php中mysql事务回滚无效怎么办

更多相关技术文章,请访问PHP中文网

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
怎么学好php
来自于 1970-01-01 08:00:00
0
0
0
PHP扩展intl
来自于 1970-01-01 08:00:00
0
0
0
php数据获取?
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板