事务的四大特性和隔离级别

事务有四大特性:

ACID:

 A(Atomicity) 原子性:表示一个事务就是一个最小的单位,不可再被分割,一个事务所作的操作要么全部成功提交,要么全部失败回滚;

C(Consistency) 一致性:举个例子:银行系统中A,B两位加起来有总金额3000块钱,不论A和B之间怎样互相转账,转多少次账,A,B两位用户加起来的钱还是3000块;

I(Isolation) 隔离性:一个事务在最终提交之前是不可见的,事务之间互相隔离;

D(Durability) 持久性:一旦事务提交之后,所作的操作会永久生效,即使系统崩溃。

 

 事务的四个隔离级别

Read Uncommited 读未提交;

Read Commited 读已提交;

Repeatable Read 可重复读;   MySQL的默认隔离级别;

Serializable 可序列化。

 

脏读:一个事务读取到了别的事务还没提交的数据,将隔离级别设置成Read Commited 及以上可以避免脏读;

不可重复读:在一次事务内,先后两次读取到了不同的数据,原因是在该次事务内第二次读取的过程中其他事务进行了更新操作,将隔离级别设置成Repeatable Read 及以上可以避免不可重复读问题;

幻读:在一次事务内,先后查询到的结果条数不一致,原因是在该次事务内第二次查询的过程中其他事务进行了添加操作;理论上Repeatable Read隔离级别不可以避免幻读,但是MySQL通过对读取到的数据加锁,可以避免幻读,

总结:隔离级别Read Commited可以避免脏读;隔离级别Repeatable Read可以避免不可重复读和幻读;隔离级别Serializable通过对所有事务排序,使它们之间不会发生冲突,从而避免脏读、重复度、幻读的问题,但是由于实质上就是在每个读到的数据行上加锁,会导致大量的锁竞争和超时,因此实际中很少使用这个隔离级别。

 

在进行事务操作前需要先开启事务

start transaction;

如果不使用事务直接使用SQL语句执行操作,所有的操作都是自动提交的。开启了事务之后,则需要手动提交事务中所进行的操作:

commit;

如果要修改事务隔离级别

set session transaction isolation level read commit;

如果要取消事务内的操作(回滚还未提交的事务):

rollback;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值