MySQL数据库进阶(事务Transaction)

1、事务定义

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

2)能保障安全
一个最小的不可再分的工作单元,通常一个事务对应一个完整的业务。如:手机转账,该业务就是一个最小的工作单元,它涉及了你各方面的信息和转账对方的信息,这是一种链接式的。你的账户钱少了,对方账户钱多了,两者必须都成功了,这项操作才算真正结束,如果进行到一半出问题了,你的钱是不会少的,因为这一个事务还没有结束。

3)事务前提

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

综上所述,事务指逻辑上的一组操作,组成这组操作的各个单元,要不全部成功,要不全部不成功。

2、事务的四大特征

1)原子性: 一个事务中的所有操作,要么都发生,要么都不发生,不会结束在中间某个环节。

2)一致性: 在事务开始之前和事务结束以后,数据库的完整性没有被破坏。无论事务是否执行成功,事务结束后的数据库中的数据也应该是符合完整性约束的。

3)隔离性: 多个用户并发访问数据库时,一个用户的事务不能被其它用户的事务所干扰。

4)持久性: 一个事务一旦被提交,就代表一个事务的结束,它对数据的修改就是永久的,即便系统故障也不会丢失。

注意:

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

3、事务操作
  • 开启事务: Start Transaction
  • 事务结束: End Transaction
  • 提交事务: Commit Transaction
  • 回滚事务: Rollback Transaction
    即撤销指定的sql语句(只能回退insert delete update语句),回滚到上一次commit的位置
  • 设保留点: Savepoint identifier
    事务处理中设置的临时占位符 你可以对它发布回退(与整个事务回退不同)
  • 删保留点: Release Savepoint identifier
  • 改提交模式:
    SET AUTOCOMMIT=0 禁止自动提交
    SET AUTOCOMMIT=1 开启自动提交
4、savepoint练习

1)首先创建带有innodb引擎的数据表

--创建使用事务引擎的数据表(设置engine为innodb)
create table emp(id INT PRIMARY KEY auto_increment,name VARCHAR(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鸿蒙Next

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值