MySQL事务(transaction)
MySQL的主要操作就是增删改查,而事务可以理解为这些操作的一个集合,比如当要删除一个成员的时候,要删除的是多个与该成员相关的信息,这个时候事务就可以完成多个操作。
事务的特点4个条件(ACID):
- 原子性:一个事务的操作,要么全部完成,要么就全部不完成。当完成到中间出错时,就会被回滚,数据库的状态会回到事务开始之前的状态。
- 一致性:事务在开始之前和结束之后,数据库的完整性没有被破坏。比如写入性的事务,其保证完整性的方法就是写入的资料符合所有的预设规则,比如资料的精确度,串联性以及后续数据库可以自发性的完成预定操作。
- 隔离性:数据库允许并发,也就是说数据在事务操作的时候要保证其线程安全性,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据不一致。
- 永久性:事务的处理结束过后,其修改是永久的,即使是系统故障也不会丢失。
事务的控制语句:
- 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。
事务自动提交和非自动提交
SETAUTOCOMMIT=1 开启自动提交 | 默认方式,执行SQL语句过后会马上执行COMMIT操作 |
SETAUTOCOMMIT=0 关闭自动提交 | 显式的执行事务操作,主要通过BEGIN、ROLLBACK、COMMIT来实现 |