博客列表 >tp5 事务处理

tp5 事务处理

技术宅的博客
技术宅的博客原创
2019年04月02日 16:30:523944浏览

比如:你给我转账10000块,需要把你的余额减10000,我的加10000,如果万一我的余额写入失败,那么理应你的余额不变,  不然这10000就蒸发了

Db::startTrans();
try{
   $res1=Db::table('think_user')->find(1);
   $res2=Db::table('think_user')->delete(1);
   /*
       这里需要抛出异常 才会执行回滚 
       这个tp5的实例  Db类会自动抛出异常 所以不用判断 
       最好的是加上判断
   */
   if($res1 && $res2){
       // 提交事务
       Db::commit(); 
       // 提示成功语句
   }
 } catch (\Exception $e) {
   // 回滚事务
   Db::rollback();
   // 提示失败语句
}

特别注意是 数据库 必须是InonDb引擎才支持事务,如果此方法没有效果时 请及时检查涉及的表是否是InonDb引擎

看你的mysql现在已提供什么存储引擎:

show engines;

看你的mysql当前默认的存储引擎:

show variables like '%storage_engine%';

你要看某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎):

show create table 表名;

修改表引擎方法

alter table 表名 engine=innodb;




上一条:php EOF(heredoc)下一条:mysql 事务
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议