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

相关文章

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java8 Collectors.toMap() 的两种用法

《Java8Collectors.toMap()的两种用法》Collectors.toMap():JDK8中提供,用于将Stream流转换为Map,本文给大家介绍Java8Collector... 目录一、简单介绍用法1:根据某一属性,对对象的实例或属性做映射用法2:根据某一属性,对对象集合进行去重二、Du

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

vue监听属性watch的用法及使用场景详解

《vue监听属性watch的用法及使用场景详解》watch是vue中常用的监听器,它主要用于侦听数据的变化,在数据发生变化的时候执行一些操作,:本文主要介绍vue监听属性watch的用法及使用场景... 目录1. 监听属性 watch2. 常规用法3. 监听对象和route变化4. 使用场景附Watch 的

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

Java Instrumentation从概念到基本用法详解

《JavaInstrumentation从概念到基本用法详解》JavaInstrumentation是java.lang.instrument包提供的API,允许开发者在类被JVM加载时对其进行修改... 目录一、什么是 Java Instrumentation主要用途二、核心概念1. Java Agent

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

Java 中 Optional 的用法及最佳实践

《Java中Optional的用法及最佳实践》在Java开发中,空指针异常(NullPointerException)是开发者最常遇到的问题之一,本篇文章将详细讲解Optional的用法、常用方... 目录前言1. 什么是 Optional?主要特性:2. Optional 的基本用法2.1 创建 Opti