最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

ThinkPHP6中的事务操作

来源:动视网 责编:小采 时间:2020-11-02 22:06:49
文档

ThinkPHP6中的事务操作

ThinkPHP6中的事务操作:事务操作对很多新人来说,可能有点陌生,即使看了ThinkPHP6官方手册中事务操作的部分,也仍然不知所解。下面就给大家介绍下事务操作。一、先说说使用场景。假设我需要给朋友转账1000元钱,正常的业务逻辑是:1、银行从我的账户中扣除1000元 2、银行给朋友账
推荐度:
导读ThinkPHP6中的事务操作:事务操作对很多新人来说,可能有点陌生,即使看了ThinkPHP6官方手册中事务操作的部分,也仍然不知所解。下面就给大家介绍下事务操作。一、先说说使用场景。假设我需要给朋友转账1000元钱,正常的业务逻辑是:1、银行从我的账户中扣除1000元 2、银行给朋友账


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

ThinkPHP6中的事务操作:事务操作对很多新人来说,可能有点陌生,即使看了ThinkPHP6官方手册中事务操作的部分,也仍然不知所解。下面就给大家介绍下事务操作。一、先说说使用场景。假设我需要给朋友转账1000元钱,正常的业务逻辑是:1、银行从我的账户中扣除1000元 2、银行给朋友账
推荐度:
标签: 操作 中的 事务
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top