• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >MsSql > SQL2008中SQL应用之-锁定(locking) 应用分析

SQL2008中SQL应用之-锁定(locking) 应用分析

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了sql2008,sql2008安装图解,sql2008密钥,sql2008数据库下载,sql2008 64位下载等相关知识,希望本文的分享对您有所帮助

一、锁的基本概念:

锁定(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动态视图监视数据库中锁的活动。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 迁移sql2005到sql2008r2步骤
  • 基于SQL2005 SQL2008 表结构信息查询升级版的详解(含外键信息)
  • 同时安装vs2005团队开发版和sql 2005企业版的方法(downmoon原作)
  • sql2008 附加数据库时出现错误5123提示的解决方法
  • MSSQL 2005 安全设置图文教程
  • SQL2008中SQL应用之-阻塞(Blocking)应用分析
  • SQL2008中SQL应用之-锁定(locking) 应用分析
  • SQL2008中通过DBCC OPENTRAN和会话查询事务
  • 关于MSSQL 2005的安装与补丁
  • MSSQL 字符段分段更新

相关文章

  • 2017-05-11SQL Server 2005与sql 2000之间的数据转换方法
  • 2017-05-11如何在SQL Server 2005数据库中导入SQL Server 2008的数据
  • 2017-05-11win2008 enterprise R2 x64 中安装SQL server 2008的方法
  • 2017-05-11SQLserver 2005文件和文件组的作用说明
  • 2017-05-11sql2008启动代理未将对象应用到实例解决方案
  • 2017-05-11sqlserver FOR XML PATH 语句的应用
  • 2017-05-11SQL Server 2005通用分页存储过程及多表联接应用
  • 2017-05-11sql server 2008数据库连接字符串大全
  • 2017-08-28oracle转 SQLServer
  • 2017-05-11安装SQL2005 29506错误码的解决方案

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • SQL2005的默认端口的修改方法
    • SQL2005 服务器因重装改名后出错的说明
    • SQL2005 学习笔记 公用表表达式(CTE)
    • 安装SQL2005 29506错误码的解决方案
    • 图文详解SQL Server 2008R2使用教程
    • SQL2008中SQL应用之-锁定(locking) 应用分析
    • SQLServer分布式事务问题
    • SQL Server 移动系统数据库
    • SqlServer2005 链接服务器用法
    • sql2005 批量更新问题的解决方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有