摆脱困惑正确认识隔离级别的标准定义

王朝other·作者佚名  2008-06-01
窄屏简体版  字體: |||超大  

虽然ANSI/ISO SQL92标准有很详细的说明,但许多人看完之后都是一头雾水,本文将对其定义进行详细的说明。

l 未提交读(read uncommitted)

l 提交读(read committed)

l 重复读(repeatable read)

l 序列化(serializable)

说明:

◆隔离级别0与事务无关,并且不加锁,也就是说例如select * from t1,系统扫描过和读取的每一行都不加锁。

◆隔离级别1与事务无关,只对正在取数的行加锁,取完数马上开锁,也就是说,begin tran 然后select * from t1即使没有commit,锁也会自动打开。

◆隔离级别2与事务有关,对扫描过的地方加锁。例如,select * from t1,系统从第1行开始扫描,扫描到第5行的时候,1到5行都处于锁定状态,直到commit,这些锁才解开。

◆隔离级别3与事务有关,对全表加锁。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航