【译】SQL Server误区30日谈-Day8-有关对索引进行在线操作的误区
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVERYTHING!!,经过我们团队的翻译和整理发布在AgileSharp上。希望对大家有所帮助。
误区 #8: 在线索引操作不会使得相关的索引加锁
错误!
在线索引操作并不是想象的那么美好。
在线索引操作会在操作开始时和操作结束时对资源上短暂的锁。这有可能导致严重的阻塞问题。
在线索引操作开始时,会在被整理的资源上加一个共享的表锁,这个表锁在会在新的索引创建时、老索引进行版本扫描时一直持续。
但问题是,这个S锁会和表上的其它锁排成锁队列。这也就是意味着和S锁不兼容的其它锁在表上存在S锁或是表上的锁队列存在中包含S锁时,这类和S锁不兼容的锁操作也需要等待。这也意味着各种更新操作会被阻塞。同样,如果表上存在X锁或是IX锁时,S锁请求也会被阻塞。
上述步骤完成后,S锁会被去掉,但你可以发现这已经对数据更新产生了影响。这期间还会造成所有等待的更新操作的执行计划被重新编译
在线索引整理在开始需要加锁的部分完成后,剩下的大部分时间是不需要任何锁的。(这个大部分指的是整个在线索引整理的大部分时间)
当在线索引操作完成后,新建立的索引和老的索引上面都需要加一个构架修改锁(SCH_M锁)来完成最终操作。这个锁可以想象成一个更强的表级排它锁。这个锁存在期间不允许对表做任何操作,针对表的执行计划也不能重编译。
在线索引操作最终阶段的阻塞问题和在线索引操作开始时由S锁造成的阻塞问题非常类似-在SCH_M锁持续或者等待被授予期间,不允许对表进行任何操作。反之,表中存在任何读写操作时,SCH_M锁也不能被授予。
在最终阶段的SCH_M锁持续期间,旧的索引会被执行延迟DROP操作,元数据所指向的分配结构指向新的索引(所以index id不变),表的版本被更新,恭喜,现在开始你已经拥有了一个全新的索引。
如你所见,在线索引操作的开始和结束阶段潜在存在着巨大的阻塞问题。所以技术上对在线索引操作应该称为“大部分时间在线索引操作”,但这种叫法可不会受到市场的欢迎。如果你想对在线索引操作了解更多,请阅读白皮书:Online Indexing Operations in SQL Server 2005。
译者注:汪洋有一篇关于在线索引操作非常详细的文章,有兴趣的同学可以阅读: 联机索引的工作方式 ,下面我摘抄他文章中的一个图片来让在线索引操作的步骤更加清晰。
转载于:https://www.cnblogs.com/CareySon/archive/2012/10/25/2738334.html
【译】SQL Server误区30日谈-Day8-有关对索引进行在线操作的误区相关推荐
- 【译】SQL Server误区30日谈-Day1-正在运行的事务在服务器故障转移后继续执行
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- 【译】SQL Server误区30日谈-Day7-一个实例多个镜像和日志传送延迟
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- 【译】SQL Server误区30日谈-Day2-DBCC CHECKDB会导致阻塞
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- SQL Server误区30日谈-Day21-数据损坏可以通过重启SQL Server来修复
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- SQL Server误区30日谈-Day26-SQL Server中存在真正的“事务嵌套”
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- SQL Server误区30日谈-Day27-使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
本系列文章是我在sqlskill.com的PAUL的博客看到的,很多误区都比较具有典型性和代表性,原文来自T-SQL Tuesday #11: Misconceptions about.... EVE ...
- 误区30日谈16-20
--17 a)页校验和(Page CheckSum)在从 SQL Server 2000或升级上来之后自动开启 --答案: 错误 --解释:SQL SERVER 2005 后的数据库默认使用 CHEC ...
- 误区30日谈21-24
--误区#21: 数据库损坏可以通过重启 SQL Server或是Windows, 或是附加和分离数据库解决 --答案:错误 --解释:数据库损毁无任何操作可修复,但可以通过某些机制来修复页损坏 (还 ...
- SQL Server 2005 性能优化实战系列(文章索引)
http://www.cnblogs.com/gaizai/archive/2012/01/20/2327814.html 前言 性能优化是数据库方向一个很重要的技能,这也是快速提供企业级应用性能最快 ...
最新文章
- AI模型落地难?试试这个15分钟搞定的开源工具
- Laravel之路——file缓存修改为redis缓存
- python中可选参数的特征_sklearn特征选择方法及参数
- Jetty架构解析及应用示例
- alibab仓库 idea_01.微服务架构编码、构建
- java 微信申请退款的开发
- 如何使用 vCenter 警报自动监控 VSAN 组件阈值?
- 如何使用以下命令 ls cat mv touch 以及如何使用 explainshell.com 这个网站
- xcode 此工作区的项目包含使用Swift 3.x开发的源代码。此版本的Xcode不支持生成或迁移Swift 3.x目标。使用Xcode 10.1将代码迁移到Swift 4。
- Java基础语法实例(2)——实习第二天
- GIT 操作中 Reinitialized existing Git repository in.......解决方法?
- 曲奇云盘资源搜索引擎_曲奇云盘下载-曲奇云盘官网版v3.2.4-sosyes
- linux wget 安装包,linux系统下安装wget。
- java 判断生日和当前时间 对比
- 1、Visual Studio 2017安装
- 霍纳法则(Horner‘s rule)
- 日均5亿查询量的京东到家订单中心,为什么舍MySQL用ES?
- mapgis同arcmap之间的数据转换, 投影变换,误差校正,坐标,基础资料,教程的相关信息的汇集...
- 统计字符串中出现频率最高的字母 C语言
- 4.1 不定积分的概念与性质
热门文章
- JavaScript一次性定时器的设置和取消
- MySQL查询出2门及2门以上不及格者的平均成绩
- Oracle实现数据增删改的sql语句实例
- 编译器不识别stm指令_编译器简介
- Qt Creator常用快捷键及技巧提升编码效率
- css去除div连速点击的蓝色高亮效果
- 单线程和多线程的区别_谷歌下载东西超慢?开启Chrome多线程下载,下载速度提升10倍+...
- 2.4.1 算术逻辑单元ALU与加法器(串行加法器、并行加法器、全加器)
- win10任务管理器快捷键_你都知道吗?Win10任务管理器到底藏了多少秘密
- 编程三角形面积公式_三角形面积公式110式(英文版)