SQL Server DBA面试知识点(七)-- 锁

锁有两个维度的属性,粒度和类型,下面分别描述。

锁的粒度granularity

粒度即一个锁控制的范围,SQL Server中有RID (row identifier) , key, page, extent, table, db。如RID用于Heap中的行锁,key为index用的行锁,表锁即范围为整张表的锁。
由定义可知,粒度越小并发性越高,反之亦然。例如两个用户分别修改一张表中不同的两行数据,且都使用的是行锁,那么这两个用户的修改互不干扰。但如果其中一个用户使用了表锁,则另一个用户需要等到第一个用户修改完毕,释放表锁后才能进行,因此事务之间更容易被阻塞。
使用何种粒度的锁,是SQL Server的自动行为,通常不需要人为干涉。但我们也可以人为指定锁的粒度,甚至是否使用锁,方法是在SQL中使用query hint。
SQL Server选择锁粒度的原则是在资源充足,保证一致性的情况下,尽量使用小粒度锁以提高并发度。但由于SQL Server在内存中管理锁,因此当数据库出现内存压力时,SQL Server会上升锁的粒度(例如行锁变表锁)。这样用户修改一张表时,以前可能需要例如1000个行锁,现在只需要一个表锁,从而节省了资源。

锁的类型mode

SQL Server的锁类型有Shared(S),update(U), exclusive(X), intent, schema, bulk update(table lock).
对于不同的SQL,SQL Server自动选择锁的类型。例如用户A正在运行一个表查询SQL,SQL Server会在该SQL运行期间在涉及的数据加上共享锁,意为“嗨!我正在查询这些数

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值