Mysql事务的学习
Mysql的定义
事务(Transaction):一个最小的不可再分的工作单元;通常一个事务对应一个完整的业务(例如银行账户转账业务,该业务就是一个最小的工作单元)。事务只和 DML 语句有关,或者说 DML 语句才有事务。
MySQL 中事务的使用
1、开启事务
start transaction;
或者
begin transaction;
2、提交事务
commit;
3、回滚事务
rollback;
事务的特征
事务四大特征(ACID):
1、 原子性(A):事务是最小单位,不可再分;
2、一致性©:事务要求所有的 DML 语句操作的时候,必须保证同时成功或者同时失败;
3、 隔离性(I):同一时间,只允许一个事务请求同一数据,不同的事务之间彼此没有任何干扰;
4、 持久性(D):是事务的保证,事务终结的标志(内存的数据持久到硬盘文件中)。
事务的隔离级别
1、读未提交(read uncommitted):事务 A 和事务 B,事务 A 未提交的数据,事务 B 可以读取到,这里读取到的数据叫做“脏数据”。这种隔离级别最低,一般是在理论上存在,数据库隔离级别一般都高于该级别;
2、 读已提交(read committed):事务 A 和事务 B,事务 A 提交的数据,事务 B 才能读取到。这种隔离级别高于读未提交,可以避免“脏数据”。但如果事务 A 多次读取同一数据,而事务 B 在事务 A 多次读取的过程中,对数据作了更新并提交,导致事务 A 多次读取同一数据时,结果不一致,这种现象称为“不可重复读”;
3、 可重复读(repeatable read):事务 A 和事务 B,事务 A 提交之后的数据,事务 B 读不到事务 A 提交的数据。这种隔离级别高于读已提交,但如果事务 A在修改数据的过程中(比如将所有记录状态设为1),如果事务 B 向同一张表中插入一条新记录(状态为 0),事务 A 提交后再次查询表,会发现有一条记录状态没有改成 1,好像发生了幻觉,这种现象称为“幻读”。可重复读是 MySQL 默认隔离级别;
4、 串行化(serializable):事务 A 和事务 B,事务 A 在操作数据库时,事务 B 只能排队等待。这种级别可以避免“幻读”,每一次读取的都是数据库中真实存在数据,事务 A 与事务 B 串行,而不并发。
事务隔离级别与一致性的关系也可以用下表表示:
Mysql事务的案例源码
准备数据库
CREATE DATABASE 数据库名称
创建数据表sql
CREATE TABLE `product` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`productName` varchar(50) NOT NULL,
`price` double NOT NULL,
`weight` int(11) NOT NULL,
PRIMARY KEY (`id`)
)
INSERT INTO product (id, product_name, price,weight) VALUES (1, '华为p20',2300,24);
INSERT INTO product (id, product_name, price,weight) VALUES (2, '华为p30', 3600,32);
INSERT INTO product (id, product_name, price,weight) VALUES (3, '华为mate20',4600,50);
INSERT INTO product (id, product_name, price,weight) VALUES (4, '华为mate30',5600,60);
INSERT INTO product (id, product_name, price,weight) VALUES (5, '华为p20 pro',3000,36);
INSERT INTO product (id, product_name, price,weight) VALUES (6, '华为p30 pro',4000,40);
开启事务提交事务
start transaction;-- 手动开启事务
INSERT INTO product (id, product_name, price,weight) VALUES (7, '华为mate20s',5600,55); -- 更新操作
commit;-- 提交事务,commit 之后即改变底层数据库数据
select * from product ;
开启事务回滚事务
start transaction;-- 手动开启事务
INSERT INTO product (id, product_name, price,weight) VALUES (7, '华为mate20s',5600,55); -- 更新操作
rollback;-- 回滚事务
select * from product ;