前言
在SQL Server中,如何找到一张表或某个索引拥有那些页面(page)呢? 有时候,我们在分析和研究(例如,死锁分析)的时候还真有这样的需求,那么如何做呢? SQL Server 2012提供了一个无文档的DMF(sys.dm_db_database_page_allocations
)可以实现我们的需求,sys.dm_db_database_page_allocations
有下面几个参数:
对于大表而言,如果选择“DETAILED”参数,则消耗的资源和时间非常长,这个时候非常有必要选择“LIMITED”参数。
为了更好的理解sys.dm_db_database_page_allocations
输出的数据,其实我们有必要简单了解、回顾一下SQL Server中数据存储的相关知识点。 这就涉及到页(Page)和区(Extent)的概念了。SQL Server中数据存储的基本单位是页,磁盘I/O操作在页级执行。也就是说,SQL Server读取或写入数据的最小单位就是以8 KB为单位的页。
区是管理空间的基本单位。 一个区是8个物理上连续的页的集合(64KB),所有页都存储在区中。区用来有效地管理页所有页都存储在区中。 SQL Server中有两种类型的区:
统一区: 由单个对象所有。区中的所有8页只能有一个对象使用。 混合区: 最多可由8个对象共享。区中8页中每一页都可由不同的对象所有。但是一页总是只能属于一个对象。SQL Server中页也有很多类型,具体参考下面表格。
注意事项:有些Page Type比较少见,暂时有些资料没有补充完善
PAGE_TYPE | 页类型 | 页类型码 | 描述 |
1 | Data Page | DATA_PAGE | 数据页(Data Page)用来存放数据 l 堆中的数据页 l 聚集索引中“叶子“页 |
2 | Index Page | INDEX_PAGE | 索引页(Index Page),聚集索引的非叶子节点和非聚集索引的所有索引记录 |
3 | Text Mixed Page | TEXT_MIX_PAGE | 一个文本页面,其中包含小块的LOB值以及text tree的内部,这些可以在索引或堆的同一分区中的LOB值之间共享。 A text page that holds small chunks of LOB values plus internal parts of text tree. These can be shared between LOB values in the same partition of an index or heap. |
4 | Text Tree Page | TEXT_TREE_PAGE | A text page that holds large chunks of LOB values from a single column value |
7 | Sort Page | 在排序操作期间存储中间结果的页面 | |
8 | Global Allocation Map Page | GAM_PAGE | GAM在数据文件中第三个页上,文件和页的编号为(1:2),它用bit位来标识相应的区(extents)是否已经被分配。它差不多能标识约64000个区(8k pages * 8 bits per byte),也就是4G的空间,如果数据空间超过4G,那么数据库会用另外一个GAM页来标识下一个4G空间 Bit=1: 标识当前的区是空闲的,可以用来分配 Bit=0: 标识当前的区已经被数据使用了 |
9 | Shared Global Allocation Map Page | SGAM_PAGE | SGAM在数据文件的第四个页上,文件和页编号为(1:3),它的结构和GAM是一样的,区别在于Bit位的含义不同: Bit=1:区是混合区,且区内至少有一个页是可以被用来分配的 Bit=0:区是统一区, 或者是混合区但是区内所有的页都是在被使用的 |
10 | Index Allocation Map Page | IAM_PAGE | 表或索引所使用的区的信息。 |
11 | Page Free Space Page | PFS_PAGE | 存储本数据文件里所有页分配和页的可用空间的信息 |
13 | Boot Page | BOOT_PAGE | 包含有关数据库的相关信息。 数据库中有且只有一个。它位于文件1中的第9页。 |
15 | File header page | FILEHEADER_PAGE | 文件标题页。 包含有关文件的信息。 每个文件一个,文件的第0页。 |
16 | Differential Changed Map | DIFF_MAP_PAGE | 自最后一条BACKUP DATABASE语句之后更改的区的信息 |
17 | Bulk Changed Map | 自最后一条BACKUP LOG语句之后的大容量操作锁修改的区的信息 | |
18 | a page that's be deallocated by during a repair operation | ||
19 | the temporary page that (or DBCC INDEXDEFRAG) uses when working on an index | ||
20 | a page pre-allocated as part of a bulk load operation, which will eventually be formatted as a ‘real' page |