视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
SQLSERVER的数据页面结构
2020-11-09 13:46:14 责编:小采
文档


SQLSERVER的数据页面结构 在论坛里经常有人问到SQLSERVER是怎麽存放基础表数据的,既然不想查MSDN,本人就在这里说一下吧 每一行数据在数据页面里是怎麽存放的? 结构组成:每个SQLSERVER的数据页面大致分成3个部分:页头,页尾偏移量,数据存储 这3个部分 假

  SQLSERVER的数据页面结构

  在论坛里经常有人问到SQLSERVER是怎麽存放基础表数据的,既然不想查MSDN,本人就在这里说一下吧

  每一行数据在数据页面里是怎麽存放的?

  结构组成:每个SQLSERVER的数据页面大致分成3个部分:页头,页尾偏移量,数据存储 这3个部分

  假设现在有一个表,表的结构是:

  CREATE TABLE test(

  a INT,

  b INT

  )

  他在1:100这个页面上存储数据(1是数据库的数据文件ID 亦即是FILEID,100 是PAGEID 页面编号)。

  这个页面结构大致如下图

  在页头部分,会记录页面属性,包括页面编号等,还会记录当前页面空闲部分的起始位置在哪里,这样SQLSERVER在要插入新数据的时候,就能够很快地找到开始插入的位置,,而页尾的偏移量记录了每一条数据行的起始位置。这样SQLSERVER在找每一条记录的时候,就能很快找到不会把前一条记录和后一条搞混。在图例这一页里现在有两条记录:(1,100)和(2,200)第一条记录的开始位置是96,第二条记录的开始位置是111,从126开始,是空闲的空间当页面里的数据行发生变化的时候,SQLSERVER不但要去修改数据本身,还要修改这些偏移量的值,以保证SQLSERVER能够继续准确地管理数据页面里的每一行。

下载本文
显示全文
专题