MySQL事务什么时候会自动回滚?

1. 运行环境

1). 当前使用的 Laravel 版本?

laravel 8.5

2). 当前使用的 php/php-fpm 版本?

PHP 版本:7.4.12

php-fpm 版本:7.4.12

3). 当前系统

linux centos8

4). 业务环境

开发环境

5). 相关软件版本

mysql7.5

2. 问题描述?

就是想咨询一下大佬关于事务方面的问题:

use Illuminate\Support\Facades\DB;

DB::transaction(function () {
    SQL语句1;
    SQL语句2;
});

上述语句中“语句1”与“语句2”都执行成功了,但是“语句1”执行成功返回值是“0”。请问这种情况下,事务会执行“回滚”操作吗?

3. 您期望得到的结果?

希望得到指点。

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

不会,只有 SQL 执行错误时才会发生回滚。返回 0 也是执行了,只不过没有受影响的记录而已。

3年前 评论
liziyu (楼主) 3年前
Diudiuuuu 3年前
讨论数量: 5

不会,只有 SQL 执行错误时才会发生回滚。返回 0 也是执行了,只不过没有受影响的记录而已。

3年前 评论
liziyu (楼主) 3年前
Diudiuuuu 3年前

php没有自动提交的事务,只不过方法里给封装好了,只要不报错就不会回滚,有时间可以看看里面的实现

DB::transaction(function () {
SQL语句1;
SQL语句2;
});

3年前 评论
liziyu (楼主) 3年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!