千家信息网

SQL Server内幕之数据行的结构

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,表的数据行具有图6-5 所示的一般结构 (只要数据以未压缩的形式存储)。此格式称为 FixedVar 格式, 因为所有固定长度列的数据首先存储, 后跟所有可变长度列的数据。表6-7 显示了存储在每个
千家信息网最后更新 2025年01月20日SQL Server内幕之数据行的结构

表的数据行具有图6-5 所示的一般结构 (只要数据以未压缩的形式存储)。此格式称为 FixedVar 格式, 因为所有固定长度列的数据首先存储, 后跟所有可变长度列的数据。表6-7 显示了存储在每个 FixedVar 行中的信息。


状态位 A 包含指示行属性的位图。这些位具有以下含义:


Bit 0 表示特殊的版本控制信息。在 SQL server 2012 中, 这始终是0。

Bits 1到3作为3位值,

0 (000) 表示主记录,

1 (001) 表示转发的记录,

2 (010) 表示转发存根,

3 (011) 指示一个索引记录,

4 (100) 指示一个 BLOB 片段或行溢出数据,

5 (101) 表示虚影索引记录,

6 (110) 表示虚影数据记录,

7 (111) 表示虚影版本记录。


Bit 4 表示存在空位图。在 SQL server 2012 中, 即使在任何列中都不允许有 null,

也始终存在空位图。


Bit 5 表示行中存在可变长度列。


Bit 6 表示该行包含版本控制信息。


Bit 7 在 SQL server 2012 中不使用。



状态位 B 字段中使用的唯一位表示该记录是虚影转发的记录。



您可以在图6-5 和表6-7 中看到第三个和第四个字节指示行的固定长度部分的长度。如图6-5 所示, 它的长度不包括2个字节的列数和空位图, 这取决于表中列的总数, 这是可变长度。解释这些位中数据的另一种方法是, 在该行中可以找到列数的位置。例如, 如果第三个和第四个字节 (字节 2-3) 包含值 0x0016 (即十进制 22), 则表示该行不仅在列数的值之前有22个字节, 而且还意味着可以在字节22中找到列数的值。



在每个固定长度或可变长度数据块中, 数据以创建表的列顺序存储。例如, 假设使用以下命令创建了一个表:


CREATE TABLE Test1

(

Col1 int NOT NULL,

Col2 char(25) NOT NULL,

Col3 varchar(60) NULL,

Col4 money NOT NULL,

Col5 varchar(20) NOT NULL

);


此行的固定长度数据部分包含 Col1 的数据, 后跟 Col2 的数据, 后跟 Col4 的数据。可变长度数据部分包含 Col3 的数据, 后跟 Col5 的数据。对于仅包含固定长度数据的行, 以下值为 true。


数据行第一个字节的第一个十六进制数字为 1, 表示不存在可变长度列。(第一个十六进制数字包括位4到 7; bits 6 和7总是 0, 如果不存在变长列, 则位5也是0。位4始终为 1, 因此四位的值显示为1。


数据行结束于空位图之后, 它遵循固定长度的数据 (即, 图6-5 中显示的阴影部分不会存在于只有固定长度数据的行中)。


每个数据行的总长度是相同的。



具有任何可变长度列的数据行有一个列偏移量数组, 每个非 NULL 可变长度列都有一个2字节的条目, 指示列在其中结束的行中的位置。(术语偏移和位置不是完全可互换的。偏移量是基于0的, 而位置是基于1的。偏移量为7的字节位于行中的第八字节位置。)存储具有 NULL 值的可变长度列涉及一些特殊问题, 如后面的 "null 和可变长度列" 部分所讨论的。


0