当前位置: 首页 > news >正文

MySQL 10:MySQL事务

MySQL 中的事务是由存储引擎实现的。在 MySQL 中,只有 InnoDB 存储引擎支持事务。事务处理可用于维护数据库的完整性,确保批处理的 SQL 语句要么执行要么根本不执行。事务用于管理 DDL、DML 和 DCL 操作,例如插入、更新和删除语句,这些语句默认是自动提交的。

 

例如,在银行转账时,必须保证转账绝对安全,这时需要事务参与:

update account set money = money - 200 where id = 1; 
update account set money = money + 200 where id = 2;

假如在第一次update之后,出现了意外、异常,没有执行第二次update,这时,转账会出现异常。

一、操作

MySQL的事务操作主要有以下三种:

1. 开启事务:Start Transaction

任何DML语句(insert、update、delete)被执行,标志着事务的开启。

BEGIN;
-- 或
START TRANSACTION;

2. 提交事务:Commit Transaction

成功完成后,所有DML语句操作历史记录和底层硬盘数据将同步一次。

COMMIT;

3. 回滚事务:Rollback Transaction

失败结束时,清除所有DML语句操作历史记录。

ROLLBACK;

之前所有的SQL操作其实都是有事务的,只是MySQL自动帮我们完成了。 每次执行 SQL 时,MySQL 都会自动为我们提交事务。 因此,如果要手动控制事务,就必须关闭MySQL的事务自动提交。

在 MySQL 中直接使用 SET 来改变 MySQL 的自动提交模式:

set autocommit=0; --禁止自动提交 
set autocommit=1; --开启自动提交 
create database if not exists mydb12_transcation;
use mydb12_transcation;
-- 创建账户表
create table account(id int primary key, -- 账户idname varchar(20), -- 账户名money double -- 金额
);--  插入数据
insert into account values(1,'zhangsan',1000);
insert into account values(2,'lisi',1000);-- 设置MySQL的事务为手动提交(关闭自动提交)
select @@autocommit;
set autocommit = 0;-- 模拟账户转账
-- 开启事务 
begin;
update account set money = money - 200 where name = 'zhangsan';
update account set money = money + 200 where name = 'lisi';
-- 提交事务
commit;-- 如果转账中的任何一条出现问题,则回滚事务
rollback;

二、特性

三、隔离级别

隔离(Isolate)顾名思义,就是将一个事务与另一个事务隔离开来,为什么要隔离呢? 如果一个事务正在操作的数据被另一个事务修改或删除,最终的执行结果可能不符合预期。 不这样做可能会导致其他问题。

读未提交(Read uncommitted):一个事务可以读取另一个未提交事务的数据。在最底层,任何情况下都没有保证,会造成脏读。

读已提交(Read committed):一个事务只有在另一个事务提交后才能读取数据,这样可以避免脏读导致不可重复读。

可重复读(Repeatable read):即在读取数据时(事务启动),不再允许修改操作,可以避免脏读和不可重复读的发生,但会造成幻读。

串行(Serializable):是最高的事务隔离级别。在这个层次下,事务是串行和顺序执行的,可以避免脏读、不可重复读和幻读。但是这种事务隔离级别效率低,对数据库性能消耗较大,所以一般不使用。

MySQL 的默认隔离级别是Repeatable read。

-- 查看隔离级别 
show variables like '%isolation%'; /*
设置隔离级别
set session transaction isolation level 级别字符串
级别字符串:read uncommitted、read committed、repeatable read、serializable
*/-- 设置read uncommitted
set session transaction isolation level read uncommitted;-- 设置read committed
set session transaction isolation level read committed;-- 设置repeatable read
set session transaction isolation level repeatable read;-- 设置serializable
set session transaction isolation level serializable;
http://www.lryc.cn/news/13386.html

相关文章:

  • 软件设计(十三)-原码、反码、补码、移码
  • 5.4 BGP地址聚合
  • 华为OD机试 - 数列还原(Python) | 机试题算法思路 【2023】
  • 华为OD机试题 - 新工号系统(JavaScript)| 代码+思路+重要知识点
  • Java-算法竞赛中常用的Java API之大数类
  • 了解Nginx,这一篇就够了
  • k8s删除pod或deployment
  • Visual Studio 2022: 增加对虚幻引擎的支持
  • 【Python】以邮件的方式定时发送一天的股票分析报告
  • mybatis条件构造器(二)
  • C++【类与对象】
  • 假设检验选择统计量重点-----正态总体参数的假设检验
  • 华为OD机试 - 通信误码(Python) | 机试题算法思路 【2023】
  • 设计模式之装饰者模式
  • 【第31天】SQL进阶-写优化- 插入优化(SQL 小虚竹)
  • SpringBoot自动装配的原理
  • Vue3电商项目实战-分类模块5【12-二级类目-结果区-排序组件、13-二级类目-结果区-数据加载、14-二级类目-结果区-进行筛选】
  • 计算机操作系统概述
  • 面试官让你说说react状态管理?
  • CUDA线程块的分配
  • 史密斯圆图
  • Spring国际化实现
  • 10- 天猫用户复购预测 (机器学习集成算法) (项目十) *
  • 对于《MySQL 实战45讲》的理解
  • XQuery 函数
  • Elasticsearch的安装及常用操作
  • 网络安全应急响应服务方案怎么写?包含哪些阶段?一文带你了解!
  • 11、事务原理和实战,MVCC
  • Robust Self-Augmentation for Named Entity Recognition with Meta Reweighting
  • Java基础-xml