ホームページ  >  に質問  >  本文

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

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

aResut=doInsertA
if(aResut){
   bResult=doInsertB
    if (!bResult){
        delete aResult from a
    } 
}
天蓬老师天蓬老师2726日前436

全員に返信(7)返信します

  • 高洛峰

    高洛峰2017-04-10 17:41:13

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

    返事
    0
  • PHPz

    PHPz2017-04-10 17:41:13

    改成innodb

    返事
    0
  • 怪我咯

    怪我咯2017-04-10 17:41:13

    binlog

    返事
    0
  • 黄舟

    黄舟2017-04-10 17:41:13

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

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

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

    3. 要么常备份

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

    返事
    0
  • 大家讲道理

    大家讲道理2017-04-10 17:41:13

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

    返事
    0
  • 怪我咯

    怪我咯2017-04-10 17:41:13

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

    rollback ;
    ...

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

    if(aResut){
    bResult=doInsertB

    if (!bResult){
        -- 触发异常回滚
        insert into abcdefghijklmn(a)values('a');
    } 

    }
    -- 提交
    commit ;

    返事
    0
  • 黄舟

    黄舟2017-04-10 17:41:13

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

    返事
    0
  • キャンセル返事