数据库的事务隔离级别

SERIALIZABLE(序列化,最严格) :所有的数据库事务都完全隔离,就如系统中所有的事务都顺序执行一样,一个接着一个。当然,数据库可以同时执行多个事务,只要顺序执行的“错觉”可以维护(即同时执行的多个事务不会互相干扰,或者多个事务的同时执行能保证结果的正确)。啥问题也没有,但是效率也基本上是最低的。

REPEATABLE READ(可重复读) :所有查询到的数据记录都不会被改变。即会在所有获取的数据上加上读锁,但是不会加上范围锁。这个的意思就是说,可能执行两次select count(*) from t返回的值不同,因为这两次执行中有其他事务往t中插入数据。也可以理解成,只对记录加锁,没有表级别的锁。

 

READ COMMITTED(提交读) :一个查询所获取的数据可以被其他事务修改。可能出现的问题:在T1事务中第一次读数据A和第二次读数据A的过程中,有个事务修改了A并提交,这就导致两次读到的A的值不一样。

READ UNCOMMITTED(未提交读,相当于没有事务的隔离) :一个事务可以看见另一个事务所做的未提交修改。

 

大坑待补。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值