热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

SqlServer数据组织结构

page页每个页面8KB,连续的8个页面称之为一个区extents,如:2.18MB的一个DB的区大约有2.18MB(2,293,760字节)2,293,760b8kb280个页面35个区一个页只能被一个对象所有查看数据表中的记录属于哪个文件哪个page页SELECTtop10%%physloc%%,sys.f

page页 每个页面8KB,连续的8个页面称之为一个区extents, 如:2.18MB的一个DB的区大约有 2.18 MB (2,293,760 字节)=2,293,760b/8kb=280个页面=35个区 一个页只能被一个对象所有 查看数据表中的记录属于哪个文件哪个page页 SELECT top 10 %%physloc%%, sys.f

page页

每个页面8KB,连续的8个页面称之为一个区extents,

如:2.18MB的一个DB的区大约有

2.18 MB (2,293,760 字节)=2,293,760b/8kb=280个页面=35个区

一个页只能被一个对象所有

查看数据表中的记录属于哪个文件哪个page页

SELECT top 10
%%physloc%%,
sys.fn_physlocFormatter (%%physloc%%) AS RID
FROM tableName

--注意;在64位系统中sys.fn_physlocFormatter 整理出来的格式有时候不对,需要手工根据physloc来计算,计算的方法是:

以字节为单位倒叙,如

0x0702000001002200倒叙后是
0x0022000100000207

前四位0022表示插槽号2*16+2 = 34,接下来的四位0001表示文件号,余下的00000207表示文件号2*16*16+7 = 519

DBCC TraceOn(3604)
DBCC page(数据库名,1,40995,0)
DBCC TraceOff(3604)

统一区

区中的8个页面为一个对象所有

混合区

区中的8个页面最多可被8个对象共享,新的表或索引从混合类型的区中分配页面。当该表或索引增长到8个页面时(包含表本身数据和它的索引等所有数据大小?),以后所有的分配都使用统一类型的区。

GAM页

全局分配映射(Global Allocation Map),包含页头和一些其它开销外,还有8 000字节或者说64 000bit位可用,每个bit位代表一个区(8个page),0表示已使用,1表示自由区

64000个bit位代表64000个区64000*8个page页,即2^6 *1000*2^3*8KB=2^12*1000*1000B,大约4G空间。即一个文件的每4GB空间对应一个GAM页面。

SGAM页

共享全局分区,类似GAM一个bit表示一个区,不同的是,他的1表示混合区且有可用空间;1表示未使用或无可用空间

GAM与SGAM关系表:

当前使用情况 GAM比特位设置 SGAM比特位设置
全未使用 1 0
已全部使用的混合区或统一类型区(统一区) 0 0
有页面未使用的混合区 0 1

示例:

如何找有可用空间的混合区?

直接找SGAM对应bit为1的区,此时该区对应的GAMbit为0.

提示:

如果没有可用的统一区,则SqlServer会先查找GAM页,分配一个区并作为混合区使用其中的一页。

前8个page页

下一个GAM页面出现在第一个GAM页面(页码为2)以后的每511 230个页面中(大约4G空间后),并且下一个SGAM页面出现在第一个SGAM页面(页码为3)以后的每511 230个页面中。

每一个数据库文件的页码为0的页面是文件头页面,并且每个文件仅有一页(文件头页面,页码为0)

页码0是头文件页,页码1是页面自由空间页(Page Free Space,PFS)。

sqlserver中前8个数据页顺序都是固定的,所以sqlserver能够很快确认哪些区可用,哪些区不可用。

如下图:

第0页 第1页 第2页 第3页 第4页 第5页 第6页 第7页
m_type=15 m_type=11 m_type=8 m_type=9 m_type=0 m_type=0 m_type=16 m_type=17
头文件页 PFS页 GAM页 SGAM页 保留页 保留页 DCM页 BCM页

除了第9页为数据库的BOOT页以外,从第8页到第173页为SQLServer2008内部系统表的相关存储信息,然后从第174页到第279页为未分配页面。因为第一页从0开始,所以刚好280页,即和我们看到的数据库数据文件的大小完全相等。

见前文的运算,数据库大小:2.18 MB (2,293,760 字节)=2,293,760b/8kb=280个页面=35个区。

第8页 第9页 第10页 ~ 第173页 第174~279页
m_type=1 m_type=13 m_type in (1,2,10) N/A
Data页 Boot页 主要为内部系统表相关信息 未分配

http://files.cnblogs.com/files/thaughtZhao/InternalsViewerInstaller.rar

DBCC CheckPrimaryfile('D:\MSSQL\Data\GPOSDB.mdf',2)

alter database productdb set online-- 设置联机状态
Select * From sys.dm_exec_connections-- 查看链接

select * from sys.database_files-- 查看文件组

---查看具体数据记录所在的FileID、PageID

推荐阅读
  • 在安装 SQL Server 时,选择混合验证模式可以提供更高的灵活性和管理便利性。如果您已经安装了 SQL Server 并使用单一的 Windows 身份验证模式,可以通过以下步骤将其更改为混合验证模式。 ... [详细]
  • 本文介绍了在 SQL Server 2012 客户端中格式化 SQL 查询语句的多种方法,包括内置功能和第三方工具,帮助用户提高代码可读性和维护性。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 本文详细介绍了如何解决 Microsoft SQL Server 中用户 'sa' 登录失败的问题。错误代码为 18470,提示该帐户已被禁用。我们将通过 Windows 身份验证方式登录,并启用 'sa' 帐户以恢复其访问权限。 ... [详细]
  • 配置PHPStudy环境并使用DVWA进行Web安全测试
    本文详细介绍了如何在PHPStudy环境下配置DVWA( Damn Vulnerable Web Application ),并利用该平台进行SQL注入和XSS攻击的练习。通过此过程,读者可以熟悉常见的Web漏洞及其利用方法。 ... [详细]
  • 本文详细介绍如何使用 Apache Spark 执行基本任务,包括启动 Spark Shell、运行示例程序以及编写简单的 WordCount 程序。同时提供了参数配置的注意事项和优化建议。 ... [详细]
  • docker镜像重启_docker怎么启动镜像dock ... [详细]
  • openGauss每日一练第 12 天 |学习openGauss定义数据类型
    自己安装的openGauss环境启动openGaussgsctlDgaussdatadb1start登录openGaussgsqldpostgresp26000r1.创建一 ... [详细]
  • 软件工程课堂测试2
    要做一个简单的保存网页界面,首先用jsp写出保存界面,本次界面比较简单,首先是三个提示语,后面是三个输入框,然 ... [详细]
  • 本文档介绍了如何在Visual Studio 2010环境下,利用C#语言连接SQL Server 2008数据库,并实现基本的数据操作,如增删改查等功能。通过构建一个面向对象的数据库工具类,简化了数据库操作流程。 ... [详细]
  • 数据排序、无限滚动与分页加载及子查询的使用
    本文介绍了数据排序的基本方法,包括升序和降序排列。同时探讨了瀑布流布局(无限滚动)和传统分页技术在Web应用中的应用,并详细解释了子查询的概念及其替代方案。 ... [详细]
  • 本文详细介绍了如何在Linux系统中创建和管理DB2数据库,包括用户切换、数据库创建、错误处理、连接与断开、表空间和缓冲池的创建,以及用户权限管理和数据导入导出等操作。 ... [详细]
  • 本文介绍了如何通过在数据库表中增加一个字段来记录文章的访问次数,并提供了一个示例方法用于更新该字段值。 ... [详细]
  • 在寻找轻量级Ruby Web框架的过程中,您可能会遇到Sinatra和Ramaze。两者都以简洁、轻便著称,但它们之间存在一些关键区别。本文将探讨这些差异,并提供详细的分析,帮助您做出最佳选择。 ... [详细]
  • 本文介绍了两款提高Android开发效率的插件:Lombok和SQLScout。Lombok可以帮助开发者自动处理实体类的Getter和Setter方法,使代码更加简洁;而SQLScout则提供了直观的SQLite数据库查看功能,极大地简化了数据库调试过程。 ... [详细]
author-avatar
重新入梦
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有