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

转载于:https://www.cnblogs.com/thaughtZhao/p/4253887.html

SqlServer数据组织结构相关推荐

  1. nodejs操作sqlserver数据_pyspark操作MySQL、SQLServer数据库进行数据处理操作

    欢迎访问本人的CSDN博客[Together_CZ],我是沂水寒城. https://yishuihancheng.blog.csdn.net 在大数据处理领域里面,Hadoop和spark可以说是最 ...

  2. mongodb 导出到sqlserver_迁移sqlserver数据到MongoDb的方法

    迁移sqlserver数据到MongoDb的方法 前言 随着数据量的日积月累,数据库总有一天会不堪重负的,除了通过添加索引.分库分表,其实还可以考虑一下换个数据库.我强烈推荐使用MongoDb,我举例 ...

  3. SQLServer数据表的创建

    文章目录 1 SQLServer数据表的创建 1.1 创建数据表的语法 1.2 标识列的特殊说明 1.3 建表举例 1 SQLServer数据表的创建 1.1 创建数据表的语法 create tabl ...

  4. ssh项目同时使用mysql跟sqlserver数据库_MSSQL_如何把sqlserver数据迁移到mysql数据库及需要注意事项,在项目开发中,有时由于项目 - phpStudy...

    如何把sqlserver数据迁移到mysql数据库及需要注意事项 在项目开发中,有时由于项目开始时候使用的数据库是SQL Server,后来把存储的数据库调整为MySQL,所以需要把SQL Serve ...

  5. python读取sqlserver的数据_Python实现读取SQLServer数据并插入到MongoDB数据库的方法示例...

    本文实例讲述了Python实现读取SQLServer数据并插入到MongoDB数据库的方法.分享给大家供大家参考,具体如下: # -*- coding: utf-8 -*- import pyodbc ...

  6. sqlserver数据导入hdfs和hive的解决方案

    sqlserver数据导入hdfs和hive的解决方案 参考文章: (1)sqlserver数据导入hdfs和hive的解决方案 (2)https://www.cnblogs.com/viviman/ ...

  7. SqlServer数据实时同步到mysql

    SqlServer数据实时同步到mysql 一.首先要装一个ODBC的驱动用来建立mysql的连接.http://www.mysql.com/products/connector/ 注意:一定要用32 ...

  8. confluent实时同步sqlserver数据到kafka

    安装准备 192.168.23.132 (主机名spark01) 192.168.23.133 (主机名spark02) 192.168.23.134 (主机名spark03) confluent-5 ...

  9. mysql拉取sqlserver数据_MySQL与Sqlserver数据获取

    由于项目要求,一个.net mvc登录注册的东西网站必须放弃sqlserver数据去使用MySQL数据库,因此我遇到了一些问题,并找出相应的解决方法, 因为sqlserver跟MySQL的数据引擎不同 ...

最新文章

  1. celery 停止执行中 task
  2. [暑假集训Day4T3]曲线
  3. php主键自增sql语句,sql 自动增长的主键
  4. ~~单调栈(数据结构)
  5. Android之AlterDialog介绍
  6. 3.1等待和通知API(Wait-and-Notify API Tour)
  7. STDN:Scale-Transferrable Object Detection 论文解析
  8. spring3.0学习之环境搭建
  9. 基于大数据的个性化推荐系统
  10. 局域网计算机共享加密码,局域网文件共享设置密码的方法
  11. Nginx反向代理、静态资源下载
  12. 机器学习之欠采样和过采样
  13. 计算机应用技术头像,意大利科学家应用计算机技术进行头像复原
  14. 竞赛|全球物联网数据创新大赛
  15. excel两行数据匹配【vlookup、countif】
  16. 2021年第十二届蓝桥杯大赛软件赛决赛C/C++大学A组 个人部分题解
  17. Xunsearch的使用总结
  18. Netlogon 特权提升漏洞(CVE-2020-1472)原理分析与验证
  19. Vue.js中$refs{}获取DOM元素
  20. 这 7 个牛逼项目,不来看看~~

热门文章

  1. 接口 对象 = new 实现类 与 实现类 对象= new 实现类
  2. modelandview为null的原因_一千个不用 Null 的理由!
  3. 微软关闭音乐服务器,微软关闭Zune音乐服务 Zune播放器变为MP3
  4. python解析html的库_python自带的用于解析HTML的库HtmlParser
  5. 日志文件导入到mysql_导入日志文件到mysql数据库表
  6. mysql 禁止存储过程_为什么阿里巴巴禁止使用存储过程?
  7. C语言学习笔记---浮点函数modf()和fmod()
  8. CentOS 7.x防火墙问题
  9. Java中包、导包、修饰符和内部类
  10. Anylogic 仿真建模(一)