MySQL学习【第十一篇存储引擎之事务解释】

时间:2019-03-25
本文章向大家介绍MySQL学习【第十一篇存储引擎之事务解释】,主要包括MySQL学习【第十一篇存储引擎之事务解释】使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

一.innodb的核心特点------事务

1.什么是事务

在一组数据操作执行步骤,这些步骤被视为一个单元,主要针对dml语句(update、delete、insert)

2.事务ACID特性

Atomic(原子性)
所有语句作为一个单元全部成功执行或全部取消。

Consistent(一致性)
如果数据库在事务开始时处于一致状态,则在执行该。
事务期间将保留一致状态。

Isolated(隔离性)
事务之间不相互影响。

Durable(持久性)
事务成功完成后,所做的所有更改都会准确地记录在
数据库中。所做的更改不会丢失。

 3.事务的控制语句

START TRANSACTION(或 BEGIN):显式开始一个新事务
SAVEPOINT:分配事务过程中的一个位置,以供将来引用
COMMIT:永久记录当前事务所做的更改
ROLLBACK:取消当前事务所做的更改
ROLLBACK TO SAVEPOINT:取消在 savepoint 之后执行的更改
RELEASE SAVEPOINT:删除 savepoint 标识符
SET AUTOCOMMIT:为当前连接禁用或启用默认 autocommit 模式

4.事务演示

成功事务
mysql> begin;
mysql> insert into stu(id,name,sex,money) values(1,'zhang3','m',100), (2,'zhang4','m',110);
mysql> commit;

事务回滚
mysql> begin;
mysql> update stu set name='zhang3';
mysql> delete from stu;
mysql> rollback;

6.事务自动提交

#查看自动提交
mysql> show variables like 'autocommit';
#临时关闭
mysql> set autocommit=0;
#永久关闭
[root@db01 world]# vim /etc/my.cnf
[mysqld]
autocommit=0

5.事务隐式提交情况

  a)现在版本在开启事务时,不需要手工begin,只要你输入的是DML语句,就会自动开启事务。
  b)有些情况下事务会被隐式提交

如下:

  在事务运行期间,手工执行begin的时候会自动提交上个事务
  在事务运行期间,加入DDL、DCL操作会自动提交上个事务
  在事务运行期间,执行锁定语句(lock tables、unlock tables)
  load data infile
  select for update
  在autocommit=1的时候

7.事务日志redo基本功能

  a( redo是什么

  redo,顾名思义“重做日志”,是事务日志的一种。

  b( 作用是什么

  在事务ACID过程中,实现的是“D”持久化的作用。

特性:WAL(Write Ahead Log)日志优先写
REDO:记录的是,内存数据页的变化过程