iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >SQL Server Page结构深入分析
  • 660
分享到

SQL Server Page结构深入分析

2024-04-02 19:04:59 660人浏览 泡泡鱼
摘要

SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成:db_id,file_

SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成:db_id,file_id,page_id,例如,15:1:8733,15是数据库的ID,1是数据文件的ID,8733是Page的编号,Page的编号从0依次递增。8个连续的Page组成一个区(Extent),数据文件中已分配(Allocated)的空间被分割成区的整数倍。一次磁盘io操作作用于Page级别,而空间分配的最小单元是区。

Page是用于存储数据的,不同类型的Page存储的数据是不同的,Page的结构也是不同的。有些Page是用于存储数据的,叫做Data Page,有些Page是用于存储索引结构中的中间节点的,叫做Index Page,有些Page是sql Server存储引擎使用的,用于管理Page的,叫做系统页。本文关注的是Data Page和Index Page,跟数据表有关。

日志文件没有Page结构,它是由一系列的日志记录构成的。

一,Page的结构

每一个Page都由 头部(Header),内容(Content)和行偏移量(Offset)组成,头部是在Page的开始处,占用96Bytes,用于存储Page的编号,Page的类型,分配单元(Allocation Unit)等系统信息。注:在单个Page中最多存储8060Bytes的数据。

The maximum amount of data and overhead that is contained in a single row on a page is 8,060 bytes (8 KB).

SQL Server Page结构深入分析

数据行存储在Page Header之后,数据行在Page中的物理存储是无序的,行的逻辑顺序是由行偏移(Row Offset)确定的,行偏移存储在Page的末尾,每一个行偏移是一个Slot,占用2B。行偏移连续排列在Page的末尾,称作槽数组(Slot Array)。行偏移以倒序方式存储行的偏移量,这意味着,从Page末尾向Page 开头计数,第一行的偏移量存储在Page的末尾Slot中,第二行的偏移量存储在Page末尾的第二个Slot中。

二,查看Page头部信息

Page头部信息存储的是Page的系统信息,可以使用非正式的命令来查看:


DBCC PAGE(['database name'|database id], file_id, page_number, print_option = [0|1|2|3] )
您可能感兴趣的文档:

--结束END--

本文标题: SQL Server Page结构深入分析

本文链接: https://www.lsjlt.com/news/50318.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL Server Page结构深入分析
    SQL Server存储数据的基本单元是Page,每一个Page的大小是8KB,数据文件是由Page构成的。在同一个数据库上,每一个Page都有一个唯一的资源标识,标识符由三部分组成:db_id,file_...
    99+
    2024-04-02
  • 如何深入分析SQL Server Page结构
    这篇文章将为大家详细讲解有关如何深入分析SQL Server Page结构,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。SQL Server存储数据的基本单...
    99+
    2024-04-02
  • Java数据结构之HashMap源码深入分析
    目录基本结构get方法put方法HashMap的容量为什么总是2的n次幂HashMap是Java集合框架中常用的一种数据结构,它是一种基于哈希表实现的映射表.在JDK1.8版本中,H...
    99+
    2023-05-17
    Java HashMap原理 Java HashMap Java HashMap源码
  • 如何深入浅析SQL Server 触发器
    这篇文章将为大家详细讲解有关如何深入浅析SQL Server 触发器,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。触发器是一种特殊类型的存储过程,它不同于之...
    99+
    2024-04-02
  • SQL Server的入门实战分析
    本篇内容介绍了“SQL Server的入门实战分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!环境信息:...
    99+
    2024-04-02
  • 深入浅析java中的栈结构
    深入浅析java中的栈结构?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。java 数据结构中栈结构应用的两个实例1、单词逆序。 要求从控制台读入一串字符,按回车结...
    99+
    2023-05-31
    java ava 栈结构
  • 深入解析MySQL索引数据结构
    目录概述索引数据结构 二叉树 红黑树 B-Tree B+Tree Hash 索引 InnoDB 索引实现(聚集) 索引文件和数据文件是分离的(非聚集) 聚集索引和非聚集索引 联合/复...
    99+
    2024-04-02
  • Node.js Apollo Server Lambda:深入剖析其架构和优点
    在当今云原生时代,Serverless 架构已成为构建现代化应用程序的热门选择。其中,Node.js Apollo Server Lambda 更是脱颖而出,成为构建 GraphQL API 的理想选择。本文将深入剖析 Apollo Se...
    99+
    2024-02-29
    Apollo Server Lambda、Node.js、GraphQL、Lambda 函数、Serverless
  • 深入解析Go语言的语法结构
    Go语言作为一种开源的静态类型编程语言,在近年来受到越来越多开发者的青睐。其简洁的语法结构和高效的编译速度,使得它在云计算、大数据、网络编程等领域有着广泛的应用。本文将深入解析Go语言...
    99+
    2024-04-02
  • 深入解析MySQL.proc表的结构及用途
    MySQL.proc表是MySQL数据库中存储存储过程和函数信息的系统表,通过深入了解其结构及用途,可以更好地理解存储过程和函数在MySQL中的运行机制,并进行相关的管理和优化。下面将...
    99+
    2024-03-15
    mysql 结构 proc
  • 多维度深入分析Redis的5种基本数据结构
    目录一、简介二、string(字符串)1、string(字符串)相关介绍1.1 string(字符串)的内部结构1.2 string(字符串)的扩容2、string(字符串)的指令2...
    99+
    2024-04-02
  • C语言结构体字节对齐的实现深入分析
    目录前言一、什么是字节对齐二、结构体字节对齐三、#pragma pack()的使用总结前言 本教程可能会用到一点汇编的知识,看不懂没关系,知道是那个意思就行了。使用的工具是vs201...
    99+
    2022-11-13
    C语言结构体字节对齐 C语言字节对齐
  • SQL Server中WAITFOR DELAY注入的示例分析
    这篇文章主要为大家展示了“SQL Server中WAITFOR DELAY注入的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL Server中WAITFOR DELAY注入的示例分...
    99+
    2023-06-04
  • SQL Server子查询的深入理解
    当由where子句指定的搜索条件指向另一张表时,就需要使用子查询或嵌套查询。 1 子查询 子查询是一个嵌套在select、insert、update或delete语句或其他...
    99+
    2024-04-02
  • 深入浅析Java中 IO流的继承结构
    深入浅析Java中 IO流的继承结构?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java IO体系结构看似庞大复杂,其实有规律可循,要弄清楚其结构,需要明白两点: 其对称性质...
    99+
    2023-05-31
    java io流 继承结构
  • 深入浅析Java的数据结构中的图
    本篇文章为大家展示了深入浅析Java的数据结构中的图,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1,摘要:从数据的表示方法来说,有二种表示图的方式:一种是邻接矩阵,其实是一个二维数组;一种是邻接表...
    99+
    2023-05-31
    java 数据结构
  • 对Go语言中的数组数据结构进行深入分析
    数组数据结构: 数组是一种基本的数据结构,它包含一系列元素,每个元素都有一个索引。数组中的元素可以是任何类型,包括其他数组。数组的大小在创建时确定,并且在以后不能改变。 代码示例:// 创建一个包含 5 个整...
    99+
    2024-02-01
    数据结构 解读 go数组 go语言
  • 深入Linux PAM体系结构
    一、什么是Linux-PAM 为安全起见,计算机系统只有经过授权的合法用户才能访问,在这里如何正确鉴别用户的真实身份是一个关键的问题。所谓用户鉴别,就是用户向系统以一种安全的方式提交自己的身份证明,然后由系统确认用户的身份是否属实...
    99+
    2023-06-06
  • 【深入】体系结构-003-SCN
    1、介绍 2、分类 3、SCN与数据库启动 4、SCN与数据库关闭 ...
    99+
    2024-04-02
  • 深入理解go slice结构
    文章 slice介绍 append的机制 slice tricks go data slice array的语法: [4]int{1,2,3,4}, [...]int{1,2,...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作