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 和可变长度列" 部分所讨论的。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341