SQL Server内幕之数据行的结构

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

SQL Server内幕之数据行的结构


SQL Server内幕之数据行的结构

状态位 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; 位6和7总是0,如果不存在变长列,则位5也是0。4位始终为1,因此四位的值显示为1 .


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


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



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


SQL Server内幕之数据行的结构