SQL Server 2008中SQL应用之二“锁定(locking)” (sqlserver)

技术教程 2025-05-14 12:28:14 浏览
server

一、锁的基本概念:

锁定(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) 在向表进行大容量数据复制且指定了提示时使用。
键范围 当使用可序列化事务隔离级别时保护查询读取的行的范围。 确保再次运行查询时其他事务无法插入符合可序列化事务的查询的行。

可以锁定SQL Server中的各种对象,既可以是一个行,也可以是一个表或数据库。可以锁定的资源在粒度(granularity)上差异很大。从细(行)到粗(数据库)。细粒度锁允许更大的数据库并发,因为用户能对某些未锁定的行执行查询。然而,每个由SQL Server产生的锁都需要内存,所以数以千计独立的行级别的锁也会影响SQL Server的性能。粗粒度的锁降低了并发性,但消耗的资源也较少。下表介绍SQL Server可以锁定的资源:

Server”
资源 说明
索引中用于保护可序列化事务中的键范围的行锁。
数据库中的 8 KB 页,例如数据页或索引页。
一组连续的八页,例如数据页或索引页。
堆或B 树。 用于保护没有聚集索引的表中的 B 树(索引)或堆数据页的锁。
包括所有数据和索引的整个表。
数据库文件。
用于锁定堆中的单个行的行标识符。
APPLICATION 应用程序专用的资源。
元数据锁。
ALLOCATION_UNIT 分配单元。
整个数据库。

不是所有的锁都能彼此兼容。例如,一个被排他锁锁定的资源不能被再加其他锁。其他事务必须等待或超时,直到排他锁被释放。被更新锁锁定的资源只能接受其他事务的共享锁。被共享锁锁定的资源还能接受其他的共享锁或更新锁。

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列来验证这个选项。

【编辑推荐】


硬盘怎样分区?

方法有两种:1) 打开单击我的电脑右键--管理--计算机管理---磁盘管理,这时你会看到你系统的分区,单击你的C盘右键--选择压缩卷(或扩展卷,当然这是如果你以后想扩展的时候用)。 ,点击后系统会弹出对话框,里面有你所要分区的盘符已使用大小及剩余空间的大小,接着你按照你自己的意愿将盘符分别压缩的大小输入,这样你就成功分盘了。 注:可能你分盘最后会遇到明明有30G(或者其他大小)的空间,但是就是无法分盘,那么这时候切记你需要将除了系统盘之外的其他分区定义为逻辑驱动器而非主分区,这样你就会很轻松的解决了无法分盘的忧虑啦~呵呵2)1、安装:Acronis Disk Director Suite 10.0 (支持vista),安装方法和Acronis Partition Expert 2003(支持XP) 的安装过程一样,中间让输入注册码,输入后一直下一步完成安装,然后会提示是否启动计算机,点击确定重新启动。 当然比较不完美的就是这个软件暂时依然是英文版本的,没有简体中文版。 2、重启启动计算机后,桌面上会有个“Acronis Disk Director Suite”的图标,双击运行。 第一次运行Acronis Disk Director Suite 10.0 ,和Acronis Partition Expert 200一样,仍然会提示软件的运行的模式,一种是自动模式(Automatic Mode),就是以向导模式运行,一种是手动模式(Manual Mode),Vista123建议大家使用手动模式,实际操作反而更简单。 3、进入软件的主窗体后,右上角Winzard板块里面有个Increase Free Space,我们就用这个功能来调整C盘,或者其他盘的分区点击Increase Free Space:想增加哪个分区的容量,就选择那个,下一步点击next:4 调整C盘的容量(就是你刚才第3步选择的那个要增加空间的区),根据付出空间的那个分区的剩余空间,你自己滑动鼠标选择合适的吧。 5、Acronis Disk Director Suite 10.0 会弹出一个窗口,开始locking c盘和f盘,进行硬盘分区锁定,然后,就返回到软件主窗口。 6、看到菜单栏那个旗帜的图标没,就是commit的命令,意思是开始执行。 点击之后,根据提示启动计算机。 然后Acronis Disk Director Suite 会在进入 Vista前把你的分区按照你的要求都调整好,非常方便!!注:下载时候你上网搜下(从迅雷下载的网络资源里面就有),一定要有注册码生成机和原文件程序两个一起的压缩包,我这里也有安装文件你也可以给我发邮件我会给发的。 ,你使用的vista系统的话,C盘最好放30G,别忘了下载个vista优化大师用起来也好方便的。 好了,祝你马上搞定你的问题~并祝你天天开心~

50分紧急求助:.NET 连接 Oracle 出现 "ORA-06413: 连接未打开。"

试试:1. 把这段存储到Oracle‘的客户端配置文件中,并命名:hy=(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=develop-01)(PORT=1521)))(CONNECT_DATA=(SID=hy)(SERVER=DEDICATED)))2. 在程序中用 hy进行连接 = Provider=msdaora;User ID=livell;Password=abc--123;Data Source=hy;Persist Security Info=True;3. 如不还不行,去掉 Persist Security Info=True 试试

C#编程在工作中用的多不多

c/s结构的程序一般都用C#比较多,也就是应用程序,如QQ,毕竟MS花大力气搞C#,JAVA偏向B/S结构的程序,也就是基于浏览器的程序。 不过总的来说还算很好找工作。 前些天MS在北京召开发布会,发布了vista企业版+viso2008+sqlserver2008+vs2008,超级强悍的组合,最可怕的是vs2008编写程序,css样式都可以自动生成。 所以恐怕以后C#程序员的工资会降低,工作也不太好找,因为只要鼠标点点就行,会的人自然多了很多。 以上都是个人见解。

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐