事务的四大特征
1.该如何学习复杂前言的知识/
2.数据库事务
经典事务例子:
A和B,A向B转账100万
A钱-100万(北京) , B钱+100万(重庆)
网络突然断开了。A扣减了100万,此时网络断掉了,B没有获得钱?
事务!解决4大问题!
原子性、一致性、隔离性、持久性,有个这4方面保障,数据库就安全了。
支持事务,两大类差异:
1)关系性数据库:Oracle、MySQL、SQLServer
支持事务
2)非关系型数据库:redis分布式内存 数据库、mongodb、hbase…
大多不支持事务
事务相关语句:
1)autocommit 开关,是否自动提交事务,mysql开,Oracle关
2)操作:全部完成 commit提交,全部失败rollback回滚
事务必须满足4大特征:
事务的四大特征:
**原子性:**一个事务中的所有操作,要么全部完成,要么全部不完成,不会结束在中间的某一个环节,事务在执行过程中如果发生错误,会被回滚到事务开始前的状态,就想这个事务从来没有执行过一样。]
**一致性:**在事务开始之前和事务结束之后,数据库的完整性没有被破坏。一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。
拿转账来说,假设用户A和用户B两者的钱加起来一共是5000,那么不管A和B之间如何转账,转几次账,事务结束后两个用户的钱相加起来应该还得是5000,这就是事务的一致性。
**隔离性:**隔离状态执行事务,使它们好像是系统在给定时间内执行的唯一操作。隔离性是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。
即要达到这么一种效果:对于任意两个并发的事务T1和T2,在事务T1看来,T2要么在T1开始之前就已经结束,要么在T1结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。
**持久性:**在事务完成以后,该事务所对数据库所作的更改便持久的保存在数据库之中,并不会被回滚,是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。
例如:我们在使用JDBC操作数据库时,在提交事务方法后,提示用户事务操作完成,当我们程序执行完成直到看到提示后,就可以认定事务以及正确提交,即使这时候数据库出现了问题,也必须要将我们的事务完全执行完成,否则就会造成我们看到提示事务处理完毕,但是数据库因为故障而没有执行事务的重大错误。
MYSQL 事务处理主要有两种方法:
1、用 BEGIN, ROLLBACK, COMMIT来实现
BEGIN 开始一个事务
ROLLBACK 事务回滚
COMMIT 事务确认
2、直接用 SET 来改变 MySQL 的自动提交模式:
SET AUTOCOMMIT=0 禁止自动提交
SET AUTOCOMMIT=1 开启自动提交
事务测试
#默认autocommit自动提交1,改成手动0
SET @@autocommit = 0;
#声明开启事务 ,日常事务关闭
BEGIN; #开始,开启事务
#给Jack员工薪水扣除100
UPDATE emp SET sal=sal-100 WHERE empno=100;
#给tony员工薪水加100
UPDATE emp SET sal=sal+100 WHERE empno=200;
COMMIT; #事务的提交
ROLLBACK; #程序发生异常,回滚
购买一个商品的过程:事务
1)下单
2)支付
3)物流
练习:在中间设置检查点,出错回滚到检查点,而不回滚到begin最开始的地方
SET @@autocommit = 0; #手动提交
BEGIN; #开启事务
SAVEPOINT chen; #设置检查点
UPDATE emp SET sal = sal -100 WHERE id = 1;
UPDATE emp SET sal = sal +100 WHERE id = 2;
#commit;事务提交,事务就结束了
#错误时才使用
ROLLBACK TO chen; #回滚到这个检查点
练习:删库跑路如何应对?
SET @@autocommit = 0; #手动提交
BEGIN; #开启事务
#删除
DELETE EROM emp;
#删除正确
COMMIT;
#删除错误
ROLLBACK TO 王海涛;