刚刚写好一个上线的项目,昨天来了个同窗指教指教,问到我有没有用到数据库的事务回滚,我脑子抽了一下。我貌似没有用到,错误机制都是本身设计。今天趁着偶空百度了tp的事务混滚,照猫画虎写了一个测试案例。满心期待,却发现每次都是没有回滚,刚开始觉得本身的代码有问题。百度发现myisam的数据库表是不支持事务回滚的,立马改为 innodb立马成功!数据库
$list->startTrans(); if($i ==0) { $result1 = $list->where("id=10000")->select(); $data['price'] =60; $result2 =$list->where("id=2")->save($data); } else{ $result1 =$list->where("id=1")->select(); $data['price'] =60; $result2 =$list->where("id=3")->save($data); } if($result1 && $result2){ $i=1; echo $i; $list->commit();//成功则提交 }else{ $i =5; echo $i; $list->rollback();//不成功,则回滚 }