Mysql学习笔记——事务

1、概述

2、操作

对上述案例进行讲解

数据:

create table account(

id int auto_increment primary key comment '主键ID',

name varchar(10) comment '姓名',

money int comment '余额'

) comment '账户表';

insert into account(id, name, money) VALUES (null,'张三',2000),(null,'李四',2000);

步骤如下:

复制代码
# 查询张三的账户余额
select money from account where name='张三';
# 给张三的余额减1000
update  account set money=money-1000 where name='张三';
# 给李四的余额加1000
update  account set money=money+1000 where name='李四';

在第二个语句之后加上错误(...很关键!!!)

set @@autocommit=1是自动提交,0是手动提交

在提交事务前如果程序出错,会将数据存到当前中缓存,但此时表格的数据没有变化,此时执行回滚事务,可以在当前缓存中消除改变的数据,防止出现,一个人的钱已经减了,但是另一个的还没加

复制代码
#查看设置提交方式
select @@autocommit;
set @@autocommit=0;
# 查询张三的账户余额
select money from account where name='张三';
# 给张三的余额减1000
update  account set money=money-1000 where name='张三';

程序出错...
# 给李四的余额加1000
update  account set money=money+1000 where name='李四';

#提交事务
commit;

#回滚事务
rollback ;

一种是设置事务开启的格式,一种就是下图中的开启事务的代码

3、特性

4、并发事务问题

脏读:当事务A在执行更新数据的操作时(但是并没有将数据提交到数据库),事务B读到了未提交的数据

前后两次分别去读的时候,数据发生了变化(同一行的数据发生变化)

读的时候还没有数据,事务B插入并提交,之后事务A要插入的时候又不能插入,然后再去读,发现这个数据依然不存在,但又不能插入

5、事务隔离级别

'对号'表示会出现这种情况!

相关推荐
oMcLin6 分钟前
Ubuntu 24.04系统 防火墙配置问题导致 MySQL 无法远程连接:firewalld 与 iptables 的冲突排查
linux·mysql·ubuntu
laplace01236 分钟前
LangChain 1.0 入门实战 · Part 6:LangChain Agent 中间件(Middleware)入门介绍
笔记·python·中间件·langchain·numpy·pandas
悠哉悠哉愿意12 分钟前
【嵌入式学习笔记】UART
笔记·单片机·嵌入式硬件·学习
hetao173383712 分钟前
2025-12-31~2026-1-2 hetao1733837 的刷题笔记
c++·笔记·算法
jimmyleeee19 分钟前
人工智能基础知识笔记三十一:Langfuse
人工智能·笔记
非凡ghost20 分钟前
U盘歌单管理器(适用于车载音乐U盘) 中文绿色版
前端·windows·学习·计算机外设·软件需求
laplace012329 分钟前
Part 4. LangChain 1.0 Agent 开发流程(Markdown 笔记)
前端·javascript·笔记·python·语言模型·langchain
Aliex_git29 分钟前
性能优化 - 渲染优化
前端·javascript·笔记·学习·性能优化·html
其美杰布-富贵-李34 分钟前
Spring Data Redis + Redisson 学习笔记
redis·学习·spring
wdfk_prog39 分钟前
[Linux]学习笔记系列 -- [fs]pidfs
linux·笔记·学习