事务

概念:在关系数据库中,一个事物可以是一条sql语句,一组sql语句或整个程序。

特性:
事物应该具有4个特性:原子性、一致性、隔离性、持久性、统称为ACID特性。

原子性(A)一个不可分割的工作单位,逻辑上的一组操作,要么全部成功,要么全部失败。要求必须是INNODB引擎。
一致性(C)事物必须由一个一致性到另一个一致性状态,与原子性密切相关的。有非法数据(外键约束之类),事务撤回。
隔离性(I)一个事物的执行不能被其他事物干扰。即一个事物内部的操作及使用的数据对并发的其他事物是隔离的,并发执行的各个事物之间不能相互干扰。
持久性(D)指的是一个事物一旦提交,他对数据库中数据的改变就是永久的。

用途:尤其在订单系统、银行系统中,事务是不可或缺的。这篇文章主要介绍了事务的特性,以及mysql innoDB对事务的支持。

注意:
MySQL除了innoDB和NDB,之外的一些存储引擎是不支持,事务处理的,所以改变了autocommit的值也没什么用,而且不会报错。所以在使用事务处理时一定要查看当前操作表的默认存储引擎或则特定存储引擎。

在 MySQL 命令行的默认设置下,事务都是自动提交的(隐式),即执行SQL语句后就会马上执行 COMMIT 操作。这就表示除非显式地开始一个事务,否则每个查询都被当做一个单独的事务自动执行。我们可以通过设置autocommit的值来决定是否自动提交。

一、自动提交的ON/OFF与显示事务的处理
1.)查询autocommit的值是NO,表示自动提交开启:
  mysql> show variables like 'autocommit';

2.)使用SET改变MySQL的自动提交模式:
  SET AUTOCOMMIT=0 禁止自动提交
  SET AUTOCOMMIT=1 开启自动提交

3.)显示事务的处理:
  BEGIN 开始一个事务
  ROLLBACK 事务回滚
  COMMIT 事务确认

二、事务控制语句

BEGIN 或 START TRANSACTION;   显式地开启一个事务;
COMMIT;               也可以使用COMMIT WORK,不过二者是等价的。COMMIT会提交事务,并使已对数据库进行的所有修改称为永久性的;
ROLLBACK;             有可以使用ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;
SAVEPOINT identifier;        SAVEPOINT允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT;
RELEASE SAVEPOINT identifier;    删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常;
ROLLBACK TO identifier;         把事务回滚到标记点;

SET TRANSACTION;          用来设置事务的隔离级别。InnoDB存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。

05-20 04:54