扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇文章给大家分享的是有关ThinkPHP6中事务的操作示例的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联建站服务项目包括新干网站建设、新干网站制作、新干网页制作以及新干网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,新干网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到新干省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
一、先说说使用场景。
假设我需要给朋友转账1000元钱,正常的业务逻辑是:
1、银行从我的账户中扣除1000元
2、银行给朋友账户加上1000元。
如果一切顺利,则转账成功!
那么问题来了,如果我不小心把银行账户输错,导致银行查找不到我输入的银行账户,但是这个时候钱已经从我的账户扣除了,如何处理呢?
我们生活中经常说“如果钱打不过去,银行会退回来的”,就是这个意思。
2、事务操作定义。
那么通过上面的例子,我们理解下到底什么是事务操作,事务指的是逻辑上的一组操作,组成这组操作的各个单元要么全都成功,要么全都失败。
就如上面的打钱例子,要么打钱成功,如果不成功,需要把我的钱退回来,也就是返回到初始状态,也叫做“回滚”。
3、ThinkPHP6中的事务操作。
我们理解了事务操作的使用场景,那么在ThinkPHP6中如何使用呢?
Db::transaction(function () { Db::table('think_user')->insert(['name'=>'aaa']); Db::table('think_user')->delete(1); });
我们看上面的例子,只有当我们插入记录成功的时候才会做删除操作,如果插入不成功,不会做删除操作。
比如我们故意写错一个字段name1,数据表中没有name1该字段,插入程序不会执行成功,那么下面的删除语句没有问题,但是他依然不会执行。
除此之外,我们还可以手动控制事务。看下面代码:
// 启动事务 Db::startTrans(); try { Db::table('think_user')->find(1); Db::table('think_user')->delete(1); // 提交事务 Db::commit(); } catch (\Exception $e) { // 回滚事务 Db::rollback(); }
感谢各位的阅读!关于“ThinkPHP6中事务的操作示例”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流