跟韩学AiOps系列之2025学MySQL系列_如何在MySQL中开启和提交事务?!

跟韩学AiOps系列之2025学MySQL系列_如何在MySQL中开启和提交事务?!

文章目录

在 MySQL 中,事务的开启和提交是保证数据一致性的核心操作。以下是清晰的操作步骤和示例:


一、事务的基本操作

1. 开启事务

有两种方式显式开启事务:

  • 方式 1 :使用 START TRANSACTION

    sql 复制代码
    START TRANSACTION; -- 开始事务
  • 方式 2 :使用 BEGIN

    sql 复制代码
    BEGIN; -- 与 START TRANSACTION 等效
2. 执行事务内操作

在事务内可以执行任意 SQL 操作(DML语句):

sql 复制代码
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1; -- 扣款
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2; -- 收款
SELECT * FROM accounts; -- 查询数据状态(此时数据尚未持久化)
3. 提交事务

将事务内的所有操作永久生效:

sql 复制代码
COMMIT; -- 提交事务,数据写入磁盘
4. 回滚事务

取消事务内的所有操作:

sql 复制代码
ROLLBACK; -- 回滚事务,撤销未提交的修改

二、验证示例(适用于 MySQL 5.7)

步骤 1:准备测试表和数据
sql 复制代码
-- 创建测试表
CREATE TABLE accounts (
  user_id INT PRIMARY KEY,
  balance DECIMAL(10,2)
) ENGINE=InnoDB; -- 必须使用 InnoDB 引擎

-- 插入测试数据
INSERT INTO accounts (user_id, balance) VALUES
(1, 500.00),
(2, 0.00);
步骤 2:执行转账事务
sql 复制代码
-- 开启事务
START TRANSACTION;

-- 从用户1扣款100元
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;

-- 向用户2收款100元
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;

-- 提交事务(只有提交后数据才持久化)
COMMIT;
验证结果
sql 复制代码
SELECT * FROM accounts;
-- 结果:
-- user_id=1, balance=400.00
-- user_id=2, balance=100.00

三、自动提交模式

MySQL 默认启用自动提交(每条 SQL 单独作为一个事务):

1. 查看当前自动提交状态
sql 复制代码
SELECT @@autocommit; -- 返回 1 表示启用,0 表示禁用
2. 关闭自动提交
sql 复制代码
SET autocommit = 0; -- 关闭自动提交

此时需手动执行 COMMITROLLBACK

3. 重新开启自动提交
sql 复制代码
SET autocommit = 1; -- 重新启用自动提交

四、完整示例(含回滚)

sql 复制代码
-- 关闭自动提交
SET autocommit = 0;

-- 开启事务(可选,BEGIN 也可)
START TRANSACTION;

-- 用户1尝试扣款200元
UPDATE accounts SET balance = balance - 200 WHERE user_id = 1;

-- 发现余额不足(假设余额不能为负),主动回滚
ROLLBACK; -- 所有修改撤销

-- 重新开启自动提交
SET autocommit = 1;

五、关键注意事项

  1. 存储引擎:只有 InnoDB 支持事务(MyISAM 不支持)。
  2. 隔离级别:事务的可见性由隔离级别控制(默认 REPEATABLE READ)。
  3. 锁机制 :事务中的操作可能隐式或显式加锁(如 SELECT ... FOR UPDATE)。
  4. 长事务风险:避免未及时提交的事务长时间持有锁,导致性能问题。

六、事务的典型应用场景

  • 转账操作:扣款和收款需原子性保证。
  • 订单创建:创建订单与扣减库存要一致。
  • 批量数据处理:确保批量操作的完整性。

通过合理使用事务,可以确保复杂操作的数据一致性!

相关推荐
小陈工2 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull6 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希7 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神7 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员7 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java7 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿7 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb