zoukankan      html  css  js  c++  java
  • SqlServer数据组织结构

    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:MSSQLDataGPOSDB.mdf',2)

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

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

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

  • 相关阅读:
    【转】BFT类共识协议概览与分析实测
    谈谈架构设计的八条原则
    Python爬虫入门教程 61-100 写个爬虫碰到反爬了,动手破坏它!
    Python如何实现单步调试
    Python如何实现单步调试
    Flash调用Alchemy编译的代码时出现Error #1506的解决
    Flash调用Alchemy编译的代码时出现Error #1506的解决
    Flash调用Alchemy编译的代码时出现Error #1506的解决
    Flash调用Alchemy编译的代码时出现Error #1506的解决
    showModalDialog使用讲解
  • 原文地址:https://www.cnblogs.com/thaughtZhao/p/4253887.html
Copyright © 2011-2022 走看看