一、锁的基本概念:
锁定
(Locking)
是一个
关系型
数据库
系统的常规
和必要
的一部分
,它防止对相同数据作
并发更新
或在更新过程中查看数据
,
从而保证被更新
数据的完整性
。
它也能防止
用户读取正在被修改
的数据
。
Sql Server
动态地
管理
锁定
,然而,还是很有必要
了解
Transact
- SQL查询
如何影响SQL Server中的
锁
定
。在此,简单介绍下锁的基本常识。
锁定有助于防止并发问题的发生。当一个用户试图读取另一个用户正在修改的数据,或者修改另一个用户正在读取的数据时,或者尝试修改另一个事务正在尝试修改的数据时,就会出现并发问题。
SQL Server资源会被锁定,资源的锁定方式称作它的锁定模式(lock mode),下表列出SQL Server处理的主要锁定模式:
名称
|
描述
|
共享 (S)
|
用于不更改或不更新数据的读取操作,如 SELECT 语句。
|
更新 (U)
|
用于可更新的资源中。 防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。
|
排他 (X)
|
用于数据修改操作,例如 INSERT、UPDATE 或 DELETE。 确保不会同时对同一资源进行多重更新。
|
意向
|
用于建立锁的层次结构。 意向锁包含三种类型:意向共享 (IS)、意向排他 (IX) 和意向排他共享 (SIX)。
|
架构
|
在执行依赖于表架构的操作时使用。 架构锁包含两种类型:架构修改 (Sch-M) 和架构稳定性 (Sch-S)。
|
大容量更新 (BU)
|
在向表进行大容量数据复制且指定了 TABLOCK
提示时使用。
|
键范围
|
当使用可序列化事务隔离级别时保护查询读取的行的范围。 确保再次运行查询时其他事务无法插入符合可序列化事务的查询的行。
|
可以锁定SQL
Server中的各种对象,既可以是一个行,也可以是一个表或数据库。可以锁定的资源在粒度(granularity)上差异很大。从细(行)到粗(数据
库)。细粒度锁允许更大的数据库并发,因为用户能对某些未锁定的行执行查询。然而,每个由SQL
Server产生的锁都需要内存,所以数以千计独立的行级别的锁也会影响SQL
Server的性能。粗粒度的锁降低了并发性,但消耗的资源也较少。下表介绍SQL Server可以锁定的资源:
资源
|
说明
|
KEY
|
索引中用于保护可序列化事务中的键范围的行锁。
|
PAGE
|
数据库中的 8 KB 页,例如数据页或索引页。
|
EXTENT
|
一组连续的八页,例如数据页或索引页。
|
HoBT
|
堆或 B 树。 用于保护没有聚集索引的表中的 B 树(索引)或堆数据页的锁。
|
TABLE
|
包括所有数据和索引的整个表。
|
FILE
|
数据库文件。
|
RID
|
用于锁定堆中的单个行的行标识符。
|
APPLICATION
|
应用程序专用的资源。
|
METADATA
|
元数据锁。
|
ALLOCATION_UNIT
|
分配单元。
|
DATABASE
|
整个数据库。
|
不是所有的锁都能彼此兼容。例如,一个被排他锁锁定的资源不能被再加其他锁
。其他事务必须等待或超时,直到排他锁被释放。被更新锁锁定的资源只能接受其他事务的共享锁。被共享锁锁定的资源还能接受其他的共享锁或更新锁。
SQL Server自动分配和升级锁。升级意味着细粒度的锁(行或页锁)被转化为粗粒度的表锁。当单个T-SQL语句在单个表或索引上获取5000多个锁,或者SQL Server实例中的锁数量超过可用内存阈值时,SQL Server会尝试启动锁升级。
锁占用系统内存,因此把很多锁转化为一个较大的锁能释放内存资源。然而,在释放内存资源的同时会降低并发性。
SQL Server 2008带来了新的表选项,可以禁用锁升级或在分区(而不是表)范围启用锁升级。
二、查看锁的活动
下面演示一个实例,它使用sys.dm_tran_locks动态视图监视数据库中锁的活动。
打开一个查询窗口,执行如下语句:
打开另一个查询窗口,执行:
执行结果:
解析:本示例中,我们首先启动了一个新事务,并使用TABLOCKX锁提示(这个提示对表放置了排他锁),对
Production.ProductDocument表执行了一个查询。查询sys.dm_tran_locks动态管理视力可以监视当前SQL
Server实例中打开了哪些锁。它返回了AdventureWorks数据库中活动锁的列表。可以在结果中的最后一行看到
ProductDocument表上的排他锁。
前三列定义了会话锁、资源类型和数据库ID。第四列使用了Object_Name函数,注意它使用了两个参数(对象ID和数据库ID)来指定访问哪
个名称(第二个参数是SQL Server 2005
SP2引入的,它用来指定为了转换对象名称而使用哪个数据库)。同时也查询锁定请求模式和状态,最后,From子句引用DMV,用Where子句指定了两
个资源类型。Resource_Type指定了锁定的资源类型,如Database\Object\File\Page\Key\RID\Extent
\Metadata\Application\Allocation_Unit或HOBT类型。依赖资源类型的
resource_associated_entity_id,确定ID是object ID, allocation unit ID, 或Hobt
ID。
■
如果
resource_associated_entity_id列包含Object ID(资源类型为Object),可以使用sys.objects目录视图来转换名称。
■
如果
resource_associated_entity_id
列包含allocation unit
ID(资源类型为Allocation_Unit),可以引用sys.allocatiion_units和contain_id联结到
sys.partitions上,就可以确定object ID。
■
如果
resource_associated_entity_id列包含Hobt ID(资源类型为Key\page\Row或HOBT),可以直接引用sys.partitions,然后查找相应的Object ID。
■
对于Database、Extent、 Application或MetaData的资源类型,
resource_associated_entity_id列将为0。
使用sys.dm_tran_locks
能对无法预料的并发问题进行故障调试。例如,一个查询会话占用锁的时间可能比预期时间长而被锁,或者锁的粒度或锁模式不是我们所期望的(可能是希望使用表
锁而不是更小粒度的行锁或页锁)。理解锁处于的锁定级别有助于我们更有效地对查询的并发问题进行故障调试。
三、控制表的锁升级行为
每
个在SQL Server中创建的锁都会消耗内存资源。当锁的数量增加时,内存就会减少。如果锁的内存使用百分比超过一个特定阈值,SQL
Server会将细粒度锁(页或行)转换为粗粒度锁(表锁)。这个过程称为锁升级。锁升级可以减少SQL
Server实例占有的锁数量,减少锁内存的使用。
虽
然细粒度会消耗更多的内存,但由于多个查询可以访问未锁定的行,因此也会改善并发性。引入表锁可能会减少内存的消耗,但也会带来阻塞,这是因为一条查询锁
住了整个表。根据使用数据库的应用程序,这个行为可能是不希望发生的,而且你可能希望当SQL Server实施锁升级时尽量获得更多的控制。
SQL Server 2008引入了使用ALter table命令在表级别控制锁升级的功能。现在可以从如下3个设置中选择:
■Table
这是SQL Server 2005中使用的默认行为。当设置为该值时,在表级别启用了锁升级,不论是否为分区表。
■Auto
如果表已分区,则在分区级别(堆或B树)启用锁升级。如果表未分区,锁升级将发生在表级别上。
■Disable
在表级别删除锁升级。注意,对于用了TABLOCK 提示或使用可序列化隔离级别下Heap的查询时,你仍然可能看到表锁。
下面示例演示了修改表的新设置:
下来,我们禁用锁升级:
说明:在更改了这个配置后,可以通过查询sys.tables目录视图的lock_escalation_desc列来验证这个选项。
注意:如果表未分区,通常情况为表级别升级。如果你指定了Disable选项,将不会出现表级别的锁升级。这会提高并发性,但如果你请求访问大量的行或页,会增加内存的消耗。
邀月注:本文版权由邀月和CSDN共同所有,转载请注明出处。
助人等于自助! 3w@live.cn
分享到:
相关推荐
一本面向想要了解SQL Server并发性以及如何解决过多的阻塞或死锁问题的DBA和开发人员的书。
了解和熟练掌握SQL Server 2008中的锁定机制对于优化数据库性能和解决并发问题至关重要。通过合理使用不同类型的锁,可以平衡数据的完整性和并发访问,提高系统的整体效率。在特定情况下,还可以利用SQL Server 2008...
《Expert SQL Server Transactions and Locking》是一本专为SQL Server数据库管理员和开发人员编写的权威指南,涵盖了事务处理和锁定机制这两个核心主题。这本书的源码提供了深入理解这些概念的实际示例,对于学习和...
第六章“Locking and Latches”讨论了SQL Server中的锁定和闩锁机制,这是确保数据一致性和并发控制的重要手段。锁定用于管理多个用户或进程间的资源访问冲突,而闩锁则是用于保护共享资源免受并发修改的一种内部...
- **锁定机制**:`W04_Locking_stdt.doc`可能涵盖了SQL Server的锁定级别(如行级、页级和表级锁)和模式(共享锁、排他锁),理解这些可以帮助避免死锁和提高并发性。 - **死锁检测与解决**:了解如何识别和处理...
在SQL Server中,有多种类型的锁,包括共享锁(Shared Locks)、排他锁(Exclusive Locks)、更新锁(Update Locks)和行级锁定(Row-Level Locking)。共享锁允许多个事务同时读取同一数据,但阻止任何写操作;排他...
通过以上步骤,我们成功地在VMware GSX Server环境中构建了一个基于Windows 2003 Enterprise Edition的双节点故障转移集群,并在此基础上安装了SQL Server 2000故障转移集群。这种配置能够提供高可用性和负载均衡,...
在.NET开发过程中,SQL Server作为常用的数据库管理系统,其在面试中的地位不容忽视。这份压缩包文件,名为"SQL题目",显然包含了与.NET环境下的SQL Server面试相关的试题,旨在帮助应聘者准备数据库相关的面试环节...
封锁技术在SQL Server中扮演着至关重要的角色,它包括不同类型的锁,如共享锁(S Lock)、排他锁(X Lock)、更新锁(U Lock)等,以及行级锁、页级锁和表级锁等多种粒度的锁定机制,以适应不同的并发控制需求。...
根据提供的信息,我们可以总结出以下关于SQL在个人实际工作经验中的几个关键知识点: ### SQL实际工作经验分享 #### 一、存储过程(Stored Procedures)的应用与优化 **1. 使用TableView代替直接使用表名** - **...
在SQL Server中,有多种策略来处理并发问题,其中最常见的是锁定和行版本控制。 锁定是防止并发冲突的一种方法,也称为悲观并发控制。它在用户读取或修改数据时立即获取锁,阻止其他用户在同一时刻进行修改。锁定...
本文档主要介绍了如何将 Microsoft SQL Server 2000 中的应用程序和数据移植到 IBM DB2 Universal Database (UDB) Version 8.2。这种移植涉及到的技术细节广泛,包括但不限于数据类型转换、数据库对象迁移以及系统...
例如死锁(Deadlock)或者第一读者写者问题(First-Come, First-Served Writer Problem),对于这些情况可能需要使用其他并发控制策略,如乐观锁定(Optimistic Locking)、悲观锁定(Pessimistic Locking)或者行...
SQL Server提供了多种并发控制策略,如行级锁定、页级锁定和快照隔离等。 最后,管理SQL Server的安全性包括用户权限管理、角色(Role)分配、登录(Login)控制以及审计(Auditing)机制。理解并正确配置这些安全...
- Forms Locking Mode:表单锁定模式,用于处理并发访问数据时的锁定策略。 - DataSource and DML Target:数据源和DML目标,涉及数据操作语言(DML)的执行。 - Array Size:数组大小,指定DML操作处理记录的批量...
- **配置**:通过`sp_add_backupserver`命令添加Backup Server。 **1.4.2 数据库备份和恢复** - **目的**:保护数据免受意外丢失。 - **类型**: - 完整备份 - 差异备份 - 日志备份 **1.4.3 例行备份恢复策略*...
通过双重检查锁定(double-checked locking)实现线程安全的初始化,避免并发环境下多次创建连接。 - 如果连接为null,`Dao`构造函数会尝试加载JDBC驱动并建立连接,确保在后续操作中能正常访问数据库。 3. 错误...
### SQL Server中的锁定机制 1. **锁定级别**: - 包括字段级锁、行级锁和表级锁。答案选项为B、C。 ### 数据库管理系统功能 1. **主要功能**: - 数据定义功能、数据操纵功能、数据库的建立和维护功能以及...