首页 > 后端开发 > php教程 > php+mysql怎么实现事务回滚,表是MyISAM类型的?

php+mysql怎么实现事务回滚,表是MyISAM类型的?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-06 20:08:55
原创
1169 人浏览过

MyISAM不支持事务,但如果遇到数据库错误,怎么实现回滚?例如:
一段程序要先插入a表,然后再插入b表。 逻辑如下行不行:

<code>aResut=doInsertA
if(aResut){
   bResult=doInsertB
    if (!bResult){
        delete aResult from a
    } 
}</code>
登录后复制
登录后复制

回复内容:

MyISAM不支持事务,但如果遇到数据库错误,怎么实现回滚?例如:
一段程序要先插入a表,然后再插入b表。 逻辑如下行不行:

<code>aResut=doInsertA
if(aResut){
   bResult=doInsertB
    if (!bResult){
        delete aResult from a
    } 
}</code>
登录后复制
登录后复制

改成innodb

binlog

你好,你说的没错MyISAM不支持回滚。但是有几种提前预防数据丢失的措施:如下

  1. 要么存储引擎改成InnoDB;

  2. 要么把每次执行的SQL语句保存起来;

  3. 要么常备份

楼上说了binlog我也很好奇是什么鬼,我上面的回答狭隘了。于是找到了这个东西: mysqlbinlog+MyISAM实现mysql随时随地恢复的方法

myisam不支持事务,改为innodb吧
还有binlog是可以恢复数据的,但是不能实时恢复

表用innodb吧。
然后定义一个异常,如,表不存在
begin
declare flag varchar(32);
-- 定义异常
declare exit handler for 1146
begin

<code>rollback ;
...</code>
登录后复制

end
set autocommit = 0 ; -- 开启事务
aResut=doInsertA

if(aResut){
bResult=doInsertB

<code>if (!bResult){
    -- 触发异常回滚
    insert into abcdefghijklmn(a)values('a');
} </code>
登录后复制

}
-- 提交
commit ;

没有办法,myisam是不支持事务的,换成innodb吧

如果非需要用myisam,可以这样用 先插入临时表中,如果执行成功用insert tableA from select id name from tableb.这样模拟事物。可以封装为存储过程

相关标签:
php
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系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
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板