首页 > 开发 > 综合 > 正文

ASE锁模式:AllPages DataPages DataRows

2024-07-21 02:44:00
字体:
来源:转载
供稿:网友
Sybase ASE有三种锁模式:AllPages,DataPages,DataRows

Sybase的数据有table pages和index pages,最小分配单位为pages,不同的锁模式对于table pages和index pages有不同的表现,具体如下:

Locking  Schema   Locks on Index   Locks on Data All         Pages Page     Page DataPages   Not locked     Page  DataRows    Not locked     Row

如上表所示:

1、AllPages锁模式对于并发的限制最高,他对index pages和table pages都加页锁(当页被锁住的时候,页上的所有rows都不能被其他session访问)

2、DataPages对table pages加页锁

3、DataRows:强烈建议用这个锁模式,对于oltp应用,如果用前两种锁模式会导致频繁死锁

另外,DataPages和DataRows对于index pages的控制采用latch方式,一种轻量级的锁机制(熟悉Oracle会比较清楚)

对于Sybase ASE来说,锁是非常宝贵的资源,不要长时间持有锁,所以一般我们在写应用的时候尽量减少长事务。

注:Sybase ASE缺省的事务隔离级别为Read Committed。


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表