mysql事务学习

mysql事务是什么?

MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!

  • 在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。
  • 事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
  • 事务用来管理 insert,update,delete 语句

在 MySQL 命令行的默认设置下,事务都是自动提交的,即执行 SQL 语句后就会马上执行 COMMIT 操作。因此要显式地开启一个事务务须使用命令 BEGIN 或 START TRANSACTION,或者执行命令 SET AUTOCOMMIT=0,用来禁止使用当前会话的自动提交。

MYSQL 事务处理主要有两种方法:

  1. 用 BEGIN, ROLLBACK, COMMIT来实现
  • BEGIN 开始一个事务
  • ROLLBACK 事务回滚
  • COMMIT 事务确认
  1. 直接用 SET 来改变 MySQL 的自动提交模式:

SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交

实践

准备工作:

  • mysql创建数据库test,后建表,添加基础数据
drop table if exists shiwu;
CREATE table shiwu
(
id int unsigned auto_increment primary key,
txt int unsigned
);
insert into shiwu values(null,11);
insert into shiwu values(null,22);
select * from shiwu;

使得表内如下:
sql

  • 为单个语句系列隐式禁用自动提交模式,使用以下START TRANSACTION (或者begin)语句:
START TRANSACTION;
SELECT @A:=SUM(txt) FROM shiwu;
insert into shiwu SET txt=@A;
COMMIT;

执行结果:
start transaction
添加数据完成如下:
在这里插入图片描述

  • 使用set autocommit
    首先,表内数据初始为:
    select
    执行以下sql:
set autocommit=0;
SELECT @A:=SUM(txt) FROM shiwu;
insert into shiwu SET txt=@A;
rollback;
select * from shiwu;

如图,以上sql语句执行完毕,由于rollback; 的执行,将进行事务回滚,所以结果将会回到上一个
set autocommit

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

人生莫如饥荒

如果对您有帮助,也可以给点赏钱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值