文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

SQL Server内幕之数据行的结构

2024-04-02 19:55

关注

表的数据行具有图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; bits 6 和7总是 0, 如果不存在变长列, 则位5也是0。位4始终为 1, 因此四位的值显示为1。


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


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



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


阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯