thinkphp5 事务回滚_tp5 事务处理

比如:你给我转账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;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值