事务学习(一)

一、事务概述

1.1 什么是事务?

事务 是数据库提供的一个特性,它将多个操作组成一个不可分割的单元:要么全部成功,要么全部失败。

1.2 经典案例:转账

以"冠希给美美转账1000元"为例:

  1. 从美美账户扣款1000元

  2. 向冠希账户加款1000元

这两步必须同时成功或同时失败,不能出现扣款成功但加款失败的情况。

在MySQL数据库中使用事务,提供两种方式

* 模拟转账的例子,冠希给美美转钱

二、操作事务的两种方式

第一种方式(使用命令的方式)

start transaction; ‐‐ 开启事务

update t_account set money = money ‐ 1000 where username = '冠希'; update t_account set money = money + 1000 where username = '美美';

commit; ‐‐ 提供事务(事务已经结束了,数据永久的保存到数据库中了) rollback; ‐‐ 回滚事务(事务已经结束了,数据回滚到最初始化的状态)

第二种方式(设置MySQL事务不默认提交的方式)

MySQL数据库的事务是默认提交的。

update t_account set money = money ‐ 1000 where username = '冠希';‐‐ 这一条语句默认使用了一个事务。

set autocommit = off或者0 --设置让MySql的数据库的事务不默认提交

编写SQL语句(执行完,都没有提交)

sql1

sql2

需要手动的提交或者回滚

commit;

rollback;

二、在 MySQL 中操作事务

建表语句

sql 复制代码
e table t_account(    
id int primary key auto_increment,        
username varchar(20),        
money double        
);    
    
insert into t_account values (null,'美美',10000);    
insert into t_account values (null,'冠希',10000);    
insert into t_account values (null,'小凤',10000);    
insert into t_account values (null,'熊大',10000);    
insert into t_account values (null,'熊二',10000);

在cmd窗口操作,找到所需操作的表

从美美账户扣款1000元

能够操作成功,给美美账户加款1000元,恢复原来数据

开启事务 start transaction;

回滚数据rollback

不开启事务,回滚,回滚无效

给美美账户加款1000元,恢复数据

开启事务,从美美账户扣款1000元,向冠希账户加款1000元

回滚,回滚成功

开启事务,并提交事务

回滚,回滚失败

设置MySQL事务不默认提交

更新数据

回滚,能够回滚成功

再次更新,并提交,回滚,回滚失败

相关推荐
Leon-Ning Liu2 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上2 小时前
MySQL 优化 -- 相关
数据库·mysql
Rooting++2 小时前
为什么mysql的表字段的collation会自动变
数据库·mysql
Wch1G0z8A2 小时前
Google 开源了啥,让 AI Agent 碰数据库不再是定时炸弹
数据库·人工智能·开源
暴躁小师兄数据学院3 小时前
【AI大数据工程师特训笔记】第14讲:Linux操作系统与shell脚本
大数据·人工智能·笔记
tedcloud1233 小时前
cc-switch评测:多AI Coding Agent管理工具详解
数据库·人工智能·sql·学习·自动化
土狗TuGou3 小时前
SQL内功笔记 · 第8篇:事务的四大特性与隔离级别
数据库·笔记·后端·sql·mysql·oracle
流星白龙3 小时前
【MySQL高阶】10.MySQL架构,连接层服务层
mysql
胡图图不糊涂^_^4 小时前
测试BUG篇
学习·bug·测试
智者知已应修善业4 小时前
【51单片机用T0定时器方式1,实现0.5S的时间间隔实现第一次一个灯亮、第二次二个灯亮,直到全部灯亮,然后重复整个过程】2023-12-29
c++·经验分享·笔记·算法·51单片机