事务就是要保证一组数据库操作,要么全部成功,要么全部失败。再MySQL中,事务支持是在引擎层实现的。MySQL是一个支持多引擎的系统,但并不是所有的引擎都支持事务。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。比如MySQL原生的MyISAM引擎就不支持事务,这也就是MyISAM被InnoDB取代的重要原因之一。事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。事务用来管理 insert,update,delete 语句。
一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。
事务控制语句:
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。
隔离性与隔离级别
提到事务,必须提到隔离。当数据库上有多个事务同事执行的时候,就可能出现脏读、不可重复读、幻读的问题,为了解决这些问题就有了“隔离级别”的概念。因为隔离越严实,效率越低。我们需要在二者之间寻找一个平衡点。SQL标准的事务隔离级别包括:读未提交、读提交、可重复读和串行化。
事务隔离的实现
以“可重复读”级别为例,在MySQL中,实际上每条记录在更新的时候都会同事记录一条回滚操作。记录上的最新值,通过回滚操作,都可以得到前一个状态的值。
从图中例子可以看出,即使现在有另外一个事务正在讲4改成5,这个事务跟read-微微A、B、C对应的事务是不会冲突的。但产生回滚日志只有在不需要的时候才删除,也就是说,系统会判断当没有事务再需要用到这些回滚日志的时,回滚日志会被删除的。
所以,不建议使用长事务,因为会导致大量占用存储空间。
网友评论