事务
1、概念:如果一个包含多个步骤的业务操作被事务管理,那么这些操作要么同时成功,要么同时失败。
2、操作步骤:
1.开启事务:start transaction;
2.回滚:rollback;
3.提交:commit;
3、例子:
CREATE TABLE a(
id int PRIMARY key AUTO_INCREMENT,
name VARCHAR(10),
balance DOUBLE
);
-- 添加数据
INSERT INTO a(name ,balance) VALUES ('zhangsan',1000),('lisi',1000);
select * from a;
UPDATE a SET balance =1000;
-- 张三转给李四500元
-- 0,开启事务
START TRANSACTION;
-- 张三账户-500
UPDATE a SET balance=balance-500 WHERE name='zhangsan';
-- 李四账户+500
UPDATE a SET balance=balance +500 WHERE name='lisi';
-- 执行没有问题,提交事务
COMMIT;
-- 发现出现了问题,回滚事务
ROLLBACK;
4、事务的四大特征
1.原子性:事务是最小的操作单位,不可再分。
2.持久性:当事务提交回滚后,数据库会持久化的保存数据。
3.隔离性:多个事务之间相互独立。
4.一致性:事务操作前后数据总量不变。