我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何理解SQL Server中的Forwarded Record

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何理解SQL Server中的Forwarded Record

今天就跟大家聊聊有关如何理解SQL Server中的Forwarded Record,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

存放原理

在SQL Server中,当数据是以堆的形式存放时,数据是无序的,所有非聚集索引的指针存放指向物理地址的RID。当数据行中的变长列增长使得原有页无法容纳下数据行时,数据将会移动到新的页中,并在原位置留下一个指向新页的指针,这么做的原因是由于使得当出现对Record的更新时,所有非聚集索引的指针不用变动。如图1所示。

如何理解SQL Server中的Forwarded Record

图1.Forwarded Record示意

这种由于数据更新,只在原有位置留下指针指向新数据页存放位置行,就是所谓的Forwarded Record。

Forwarded Record如何影响IO性能?

那么Forwarded Record既然是为了提升性能存在的机制,为什么又会引起性能问题?Forwarded Record的初衷是为了对堆表进行更新时,堆表上存储位置的变化不会同时更新非聚集索引而产生开销。但对于查找来说,无论是堆表上存在表扫描,还是用于书签查找,都会成倍带来额外的IO开销,下面看一个例子。

CREATE TABLE dbo.HeapTest ( id INT, col1 VARCHAR(800) )  DECLARE @index INT SET @index = 0 BEGIN TRAN WHILE @index < 100000      BEGIN          INSERT  INTO dbo.HeapTest                 ( id, col1 )         VALUES  ( @index, NULL )         SET @index = @index + 1      END COMMIT

代码清单1.新建堆表并插入10万条数据

通过代码清单1创建测试表,并循环插入10万数据。此时我们来看该堆表所占用存储的页数,如图2所示。

如何理解SQL Server中的Forwarded Record

图2.堆表空间占用

此时对该表进行更新,让原有行增长,产生Forwarded Record,此时再来看该堆表的存储。如图3所示。

如何理解SQL Server中的Forwarded Record

图3.产生8W+的forwarded record

此时我们注意到,虽然数据仅仅占到590页,但存在8W+的forwarded record,如果我们对该表进行扫描,则会看到虽然仅仅只有590页,但需要8W+的逻辑IO,大大提升了对IO的开销压力,此外由于forwarded record页与原页往往不物理连续,因此对IOPS也存在挑战。如图4所示。

如何理解SQL Server中的Forwarded Record

图4.不该产生的额外IO开销

而上面查询反映到性能计数器中,则呈现为如图5所示的结果。

如何理解SQL Server中的Forwarded Record

图5.Forwarded Record计数器增长

如何解决

看到Forwarded Record计数器,就说明数据库中存在堆表,在OLTP系统中,所有的表上都应该有聚集索引。因此可以通过在表上增加聚集索引来解决该问题。

通常来讲,只有只写不读的表设置为堆表比较合适,但如果看到存在Forwarded Reocord,则说明堆表上存在读操作,那么找到该堆表,找一个合适的维护窗口时间创建堆表则是比较理想的选择。

如果由于其他原因无法创建聚集索引,则可以对堆表进行表重建。

看完上述内容,你们对如何理解SQL Server中的Forwarded Record有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何理解SQL Server中的Forwarded Record

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL Server中如何实现错误处理

今天小编给大家分享一下SQL Server中如何实现错误处理的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、SQLServ
2023-06-30

在SQL Server中如何使用Try Catch处理异常

今天小编给大家分享一下在SQL Server中如何使用Try Catch处理异常的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧
2023-07-02

如何在SQL Server中实现和管理数据分发

在SQL Server中,您可以使用以下方法来实现和管理数据分发:使用SQL Server Replication:SQL Server提供了一种内置的数据分发机制,即复制。通过设置发布者、分发者和订阅者,可以将数据从一个数据库实例复制到另
如何在SQL Server中实现和管理数据分发
2024-06-04

SQL Server如何删除表中的重复数据

本篇内容介绍了“SQL Server如何删除表中的重复数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!添加示例数据create table
2023-06-30

如何在SQL Server中管理和优化大量的事务日志

以下是一些建议来管理和优化大量的事务日志:确保事务日志文件大小适当:确保事务日志文件的大小足够大,以容纳大量的事务数据。可以通过监控事务日志的使用情况并相应调整日志文件大小来实现。定期备份事务日志:定期备份事务日志可以帮助释放事务日志中的空
如何在SQL Server中管理和优化大量的事务日志
2024-06-04

在SQL Server中如何处理大型且复杂查询的优化

在SQL Server中处理大型且复杂查询的优化可以采取以下几种方法:使用索引:为查询涉及的表添加适当的索引可以提高查询性能。索引可以加快数据访问速度,减少查询的执行时间。使用视图:将复杂的查询封装成视图,可以简化查询语句,提高查询的可读性
在SQL Server中如何处理大型且复杂查询的优化
2024-06-03

SQL Server中的缓存机制是如何工作的

SQL Server中的缓存机制主要包括计划缓存和数据页缓存。计划缓存:SQL Server会将执行过的查询计划缓存起来,以便在下次执行相同查询时能够直接使用缓存中的计划,而不需要重新编译。这样可以节省服务器的资源,提高查询的执行效率。数据
SQL Server中的缓存机制是如何工作的
2024-06-03

sql server 数据库中sa用户被锁定如何解决

这篇文章给大家介绍sql server 数据库中sa用户被锁定如何解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、打开数据库——用Windows身份登录数据库2、登录名——双击sa(打开属性)3、常规——设置密码
2023-06-15

解释在SQL Server中如何实现灾难恢复计划

在SQL Server中,实现灾难恢复计划通常涉及以下几个关键步骤:备份数据库:首先,需要定期备份数据库以确保数据的安全性。可以使用SQL Server Management Studio或Transact-SQL语句来创建完整备份、差异备
解释在SQL Server中如何实现灾难恢复计划
2024-06-04

描述SQL Server中索引碎片的影响以及如何处理它

索引碎片是指索引中数据的物理存储并非按照逻辑顺序排列,导致数据库性能下降的情况。索引碎片会增加查询的成本,降低数据库的性能。处理索引碎片的方法包括重新组织索引和重建索引。重新组织索引是通过重新排列索引中的数据来减少碎片,而不会改变索引的定
描述SQL Server中索引碎片的影响以及如何处理它
2024-06-04

编程热搜

目录