视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
ThinkPHP6中的事务操作
2020-11-02 22:06:49 责编:小采
文档

事务操作对很多新人来说,可能有点陌生,即使看了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();
}

下载本文
显示全文
专题