您好,欢迎访问一九零五行业门户网

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

php中mysql事务回滚无效是因为数据库引擎设置为“myisam”了,该引擎是不支持事务回滚的,所以产生事务回滚无效,其解决办法就是将引擎更换为“innodb”即可恢复正常。
php中mysql事务回滚无效怎么办?
我的测试环境:appserv
<?php header("content-type:text/html;charset=utf-8"); $pdo = new pdo('mysql:host=localhost;dbname=data','root','root'); $pdo->exec('set names utf8'); $pdo->setattribute(pdo::attr_errmode,pdo::errmode_exception);#修改报错模式 #开启事务 $pdo->begintransaction(); try{ #第一次操作 $sql = 'delete from books where bid=40'; $smt = $pdo->prepare($sql); $smt->execute(); #第二次操作 $sql = 'delete from1 books where bid=39'; $smt = $pdo->prepare($sql); $smt->execute(); #成功提交 $pdo->commit(); }catch(pdoexception $e){ echo $e->getmessage().'<br>'.$e->getline(); #失败撤回 $pdo->rollback(); } ?>
如上:第二次操作出错的情况下 第一条操作没有被回滚
这时候赶紧去看看你的数据库引擎,你肯定看到是myisam,很不幸这个引擎不支持事务回滚。切换到 innodb 即可 。
更多相关技术文章,请访问!
其它类似信息

推荐信息