事务
是什么
事务由单独单元的一个或多个SQL语句组成,在这个单元中,每一个mysql语句是相互依赖的;由于整个单独单元作为不可分割的整体,那么如果单元中某条SQL语句一旦执行失败或产生失败,整个单元就会回滚。要么全部成功,要么全部失败。
在mysql中用的最多的存储引擎有:innodb,myisam,memory 等。其中innodb支持事务,而myisam、memory等不支持事务
查看mysql支持的引擎:SHOW engines
事务的四大特性
- 原子性:要么成功,要么失败。
- 一致性:状态与其他业务规则保持一致。
- 隔离性:在并发中使用。一个事务不被另一个事务所影响
- 持久性:一旦改变提交之后,数据就持久化被操作了。
分类
隐式事务:没有明显的开启和结束标记
显式事务:有明显的开启和结束标记
使用步骤:
插个小知识
DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
DQL(Data Query Language):数据查询语言,用来查询记录(数据)。
- 一般情况下,如果在一个事务中包含多个SQL语句,那么就要开启事务和结束事务;
开启事务:start transaction;
结束事务:commit或rollback。
-
开始是以第一个DML语句执行开始
-
以下面的其中之一作为结束:
COMMIT 或ROLLBACK 语句(回滚,即回滚到事务的起点,之前做的所有操作都被撤消了!)
DDL 或DCL 语句(自动提交)
用户会话正常结束
系统异常终了 -
START TRANSACTION; # 开启 UPDATE account SET balance=balance-10000 WHERE id=1; UPDATE account SET balance=balance+10000 WHERE id=2; COMMIT; # 正常结束