autocommit自动提交事务及commit、rollback用法

2024-08-21 03:20

本文主要是介绍autocommit自动提交事务及commit、rollback用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

MySQL默认开启事务自动提交,每条SQL语句都会被当做一个单独的事务自动执行。

一、查看autocommit自动提交事物状态

SHOW VARIABLES LIKE ‘autocommit’;

1、开启状态:ON

autocommit的值为ON,表示系统开启自动提交模式
在这里插入图片描述

2、关闭状态:OFF

autocommit的值为OFF,表示系统关闭自动提交模式
在这里插入图片描述

二、修改autocommit状态

1、临时修改autocommit状态

#开启自动提交模式:autocommit=ON 或者 autocommit=1
SET autocommit = ON;
SET autocommit = 1;
#关闭自动提交模式:autocommit=OFF 或者 autocommit=0
SET autocommit = OFF;
SET autocommit = 0;

以上修改autocommit 状态的操作在本次ssh连接会话中有效,新开启的会话中将失效
实操:
(1)在ssh连接会话01中设置autocommit状态为OFF
(2)查看ssh连接会话1的autocommit状态为设置后的OFF关闭自动提交模式
在这里插入图片描述
(3)查看ssh连接会话2的autocommit状态为默认的ON开启自动提交状态
在这里插入图片描述

2、长久修改autocommit状态

(1)修改my.cnf配置文件:添加autocommit=0或者autocommit=OFF
在这里插入图片描述
或者
在这里插入图片描述
(2)重启mysql服务

service mysqld restart

(3)查看autocommit状态,即可永久关闭自动提交

SHOW VARIABLES LIKE ‘autocommit’;

在这里插入图片描述

三、commit提交

1、开启自动提交事务:autocommit=ON

在这里插入图片描述

2、关闭自动提交事务:autocommit=OFF

在这里插入图片描述
注意:
information_schema.INNODB_TRX 表可以用来查看当前正在运行的事务的信息:

SELECT trx_id,trx_state,trx_started,trx_mysql_thread_id,trx_query FROM
information_schema.INNODB_TRX;

  • trx_id: 事务的 ID。
  • trx_state: 事务的状态,如 RUNNING、LOCK WAIT、ROLLING BACK、COMMITTING 等。
  • trx_started: 事务开始的时间。
  • trx_mysql_thread_id: 与该事务关联的 MySQL 线程 ID。
  • trx_query: 触发事务的 SQL 语句(如果可用且没有超过最大长度限制)

四、rollback回滚

1、开启自动提交事务:autocommit=ON

自动提交事务开启,mysql数据库操作后使用rollback回滚无法恢复操作前的数据。
在这里插入图片描述

2、关闭自动提交事务:autocommit=OFF

自动提交事务被关闭,mysql数据库操作后使用rollback回滚可以进行恢复。
在这里插入图片描述

这篇关于autocommit自动提交事务及commit、rollback用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1091976

相关文章

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

MyBatis ResultMap 的基本用法示例详解

《MyBatisResultMap的基本用法示例详解》在MyBatis中,resultMap用于定义数据库查询结果到Java对象属性的映射关系,本文给大家介绍MyBatisResultMap的基本... 目录MyBATis 中的 resultMap1. resultMap 的基本语法2. 简单的 resul

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

java中Optional的核心用法和最佳实践

《java中Optional的核心用法和最佳实践》Java8中Optional用于处理可能为null的值,减少空指针异常,:本文主要介绍java中Optional核心用法和最佳实践的相关资料,文中... 目录前言1. 创建 Optional 对象1.1 常规创建方式2. 访问 Optional 中的值2.1

git stash命令基本用法详解

《gitstash命令基本用法详解》gitstash是Git中一个非常有用的命令,它可以临时保存当前工作区的修改,让你可以切换到其他分支或者处理其他任务,而不需要提交这些还未完成的修改,这篇文章主要... 目录一、基本用法1. 保存当前修改(包括暂存区和工作区的内容)2. 查看保存了哪些 stash3. 恢