事务简介
事务(Transaction):一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)。
事务只和 DML 语句有关,或者说 DML 语句才有事务。
转账操作理解事务
以下是银行账户表 t_act(账号、余额),进行转账操作。
| actno | balance |
|---|---|
| 1 | 500 |
| 2 | 200 |
使用 update 语句实现转账操作,实现账号 1 向账号 2 转账 100 元。
-- 分析:转账操作,需要账号 1 余额减少 100 元,同时需要账号 2 余额增加 100 元。
update t_act set balance=balance-100 where actno=1;
update t_act set balance=balance+100 where actno=2;
在一个转账业务中,以上两条 DML 语句必须同时成功或者同时失败。
最小单元不可再分,当第一条 DML语句执行成功后,并不能将底层数据库中的第一个账户的数据修改,只是将操作记录了一下;这个记录是在内存中完成的;当第二条 DML 语句执行成功后,和底层数据库文件中的数据完成同步。若第二条 DML 语句执行失败,则清空所有的历史操作记录,要完成以上的功能必须借助事务。
MySQL 中事务的使用
在 mysql 中,事务的常规操作包括:开启事务、提交事务与回滚事务。
开启事务
start transaction;
或者
begin;
提交事务
commit;
回滚事务
rollback;
手动开启事务,向 t_act 表中插入一行记录,提交事务。
start transaction;-- 手动开启事务
insert into t_act values(3,300); -- 更新操作
commit;-- 提交事务,commit 之后即改变底层数据库数据
select * from t_act;
运行结果:

看到这个结果,似乎和直接执行插入一条记录没什么不同。确实,在 MySQL 中,默认情况下,事务是自动提交的,也就是说,只要执行一条 DML 语句就开启了事务,并且提交了事务。
手动开启事务,向 t_act 表中插入一行记录,回滚事务。
start transaction;-- 手动开启事务
insert into t_act values(4,200); -- 更新操作
rollback;-- 回滚事务
select * from t_act;
运行结果:

从运行结果中可以看到,回滚事务会撤销更新操作,代码执行前后数据表中的数据没有发生任何变化。
事务四大特征(ACID)
原子性(A):事务是最小单位,不可再分;
一致性©:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
隔离性(I):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
持久性(D):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。
事务的隔离级别
读未提交(read uncommitted):事务 A 和事务 B,事务 A 未提交的数据,事务 B 可以读取到,这里读取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该级别;
读已提交(read committed):事务 A 和事务 B,事务 A 提交的数据,事务 B 才能读取到。这种隔离级别高于读未提交,可以避免“脏数据”。但如果事务 A 多次读取同一数据,而事务 B 在事务 A 多次读取的过程中,对数据作了更新并提交,导致事务 A 多次读取同一数据时,结果不一致,这种现象称为“不可重复读”;
可重复读(repeatable read):事务 A 和事务 B,事务 A 提交之后的数据,事务 B 读不到事务 A 提交的数据。这种隔离级别高于读已提交,但如果事务 A 在修改数据的过程中(比如将所有记录状态设为 1),如果事务 B 向同一张表中插入一条新记录(状态为 0),事务 A 提交后再次查询表,会发现有一条记录状态没有改成 1,好像发生了幻觉,这种现象称为“幻读”。可重复读是 MySQL 默认隔离级别;
串行化(serializable):事务 A 和事务 B,事务 A 在操作数据库时,事务 B 只能排队等待。这种级别可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务 A 与事务 B 串行,而不并发。
事务隔离级别与一致性的关系也可以用下表表示:
| 隔离级别 | 脏读 | 不可重复读 | 幻读 |
|---|---|---|---|
| 读未提交 | ✔ | ✔ | ✔ |
| 读已提交 | ✖ | ✔ | ✔ |
| 可重复读 | ✖ | ✖ | ✔ |
| 串行化 | ✖ | ✖ | ✖ |
本文介绍了MySQL中的事务,强调了事务作为最小工作单元的重要性,以银行转账为例解释事务的必要性。详细讲解了事务的开启、提交、回滚操作,并探讨了事务的四大特性——原子性、一致性、隔离性和持久性。接着,文章阐述了不同隔离级别的概念,如读未提交、读已提交、可重复读和串行化,以及它们在防止脏读、不可重复读和幻读方面的效果。

被折叠的 条评论
为什么被折叠?



