国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

SQL Server頁類型匯總+疑問匯總

2020-07-25 12:59:37
字體:
來源:轉載
供稿:網友

SQL Server中包含多種不同類型的頁,來滿足數據存儲的需求。不管是什么類型的頁,它們的存儲結構都是相同的。每個數據文件都包含相當數量的由8KB組成的頁,即每頁有8192bytes可用,每頁都有96byte用于頁頭的存儲,剩下的空間

才用來存儲實際的數據,在頁的最后是數據行偏移數組,也可以叫“頁槽”數組,我們可以把一個頁看做是有一個個方格的書櫥,哪行數據占用了哪個槽,都在頁尾的位置進行標示,并且頁尾數組的寫入順序是倒敘的,這樣就可以有效的利用頁空間。

由此可以預見,頁面上的“槽”并不一定是有序存放的,當有新的ID進來,并且該ID位于該頁的最大ID和最小ID之間時(假設是以ID進行排序的葉子頁),那么該ID數據行則直接插入到已經存在的數據行的后面即可,當有查詢需要檢索該ID所在的行時,

數據庫引擎從索引頁找到該“葉子”頁,將該頁全部加載到內存中,通過頁尾的行偏移數組找到對應的行。頁尾數組的記錄大小存儲在頁頭里,數組里面每一個關于“頁槽”的記錄占用空間為2bytes。

據我所知,SQL Server數據文件共有14種頁類型:

類型1――數據頁(Data Page):堆中的數據頁聚集索引中的“葉子”頁在數據文件中的位置是隨機的DBCC PAGE 中m_type=1

類型2――索引頁(Index Page):

非聚集索引非“葉子”級聚集索引在數據文件中的位置是隨機的DBCC PAGE 中m_type=2

類型3――文本混合頁(Text Mixed Page):

較短長度的LOB數據類型,多種類型,多行存儲在數據文件中的位置是隨機的DBCC PAGE 中m_type=3

類型4――文本頁(Text Tree Page):

存儲單個LOB行在數據文件中的位置是隨機的DBCC PAGE 中m_type=4

類型5――排序頁(Sort Page):

進行排序操作時的臨時頁常見于TempDB中,在用戶數據中進行“ONLINE"操作時也可見(例如:聯機創建索引未指定SORT_IN_TEMPDB選項時)在數據文件中的位置是隨機的DBCC PAGE 中m_type=19

類型6――全局分配映射頁(GAM Page):

Global Allocation Map,記錄已分配的非共享(混合)區是否已被使用每個區占用一個bit位,如果該值為1,說明該區可以使用,0則說明已被使用(但是并不一定存儲空間已滿)第一個GAM頁總是存儲在每個數據文件PageID為2的頁上DBCC PAGE 中m_type=8

類型7――共享全局分配映射頁(SGAM Page):

Shared Global Allocation Map,記錄每一個共享(混合)區是否已被使用每個區占用一個bit位,如果該值為1,說明該區有空閑的存儲空間,0則說明區已滿第一個SGAM頁總是存儲在每個數據文件PageID為3的頁上DBCC PAGE 中m_type=9

類型8――索引分配映射頁(IAM Page):

Index Allocation Map,記錄GAM頁之間堆表或者索引的區分配在數據文件中的位置是隨機的DBCC PAGE 中m_type=10

類型9――空閑空間跟蹤頁(PFS Page):

Page Free Space,跟蹤頁的可用空間。
第一個PFS頁總是存儲在每個數據文件PageID為1的頁上DBCC PAGE 中m_type=11

類型10――啟動頁(Boot Page):

存儲所在數據庫范圍的信息僅在每個數據庫文件(file)ID為1的PageID為9的頁上DBCC PAGE 中m_type=13

類型11――服務配置頁(Server Configuration Page):

存儲了sys.configurations中返回結果中的部分信息該頁僅存在于master數據庫的文件ID為1PageID為10的頁上

類型12――文件頭頁(File Header Page):

所在文件的信息總是存在于每個文件PageID為0的頁上DBCC PAGE 中m_type=15

類型13――差異更改映射(Differential Changed map):

記錄GAM之間的每次全備或差異備份之后更改過的頁面第一個DCM頁面在每個數據文件PageID為6的頁上DBCC PAGE 中m_type=16

類型14――大容量更改映射(Bulk Change Map):

記錄每個GAM之間上次備份之后大容量操作的更改第一個BCM頁面在每個數據文件PageID為7的頁上DBCC PAGE 中m_type=17

如下SQL可以查詢到你當前的數據庫中的緩存的頁類型及數量:

SELECT CASE page_type WHEN 'DIFF_MAP_PAGE' THEN '差異更改映射(Differential Changed map)' WHEN 'TEXT_MIX_PAGE' THEN '文本混合頁(Text Mixed Page)' WHEN 'ML_MAP_PAGE' THEN '這個字面意思應該是Minimally-Logged,最小化日志記錄' WHEN 'INDEX_PAGE' THEN '索引頁(Index Page)' WHEN 'FILEHEADER_PAGE' THEN '文件頭頁(File Header Page)' WHEN 'DATA_PAGE' THEN '數據頁(Data Page)' WHEN 'IAM_PAGE' THEN '索引分配映射頁(IAM Page)' WHEN 'GAM_PAGE' THEN '全局分配映射頁(GAM Page)' WHEN 'BULK_OPERATION_PAGE' THEN '這個字面意思應該是大容量更改記錄' WHEN 'TEXT_TREE_PAGE' THEN '文本頁(Text Tree Page)' WHEN 'SGAM_PAGE' THEN '共享全局分配映射頁(SGAM Page)' WHEN 'PFS_PAGE' THEN '空閑空間跟蹤頁(PFS Page)' WHEN 'BOOT_PAGE' THEN '啟動頁(Boot Page)' ELSE '排序頁?' END , page_type , COUNT(*) cntFROM sys.dm_os_buffer_descriptors WITH ( NOLOCK )WHERE database_id = DB_ID()GROUP BY page_type

結果如下圖所示:

 

按上面的數據類型介紹,我們很自然地認為類型14――大容量更改映射(Bulk Change Map)就是圖示查詢結果中第10行BULK_OPERATION_PAGE


但是事實是嗎?我們將data_type=BULK_OPERATION_PAGE的記錄查出來:

SELECT TOP 10 *FROM sys.dm_os_buffer_descriptors WHERE page_type='BULK_OPERATION_PAGE' AND DB_ID()=database_id
ORDER BY database_id,FILE_ID,page_id

查詢結果:

我們把查詢結果中的一個PageID帶入DBCC PAGE(其實這里已經看出,這個pageID并不像上面說的第一個BCM頁面在每個數據文件PageID為7的頁上,它們是邏輯上連續的頁

我們發現上面的m_type=20

我搜遍了google也沒有找到m_type=20是什么記錄!

參考網址:http://www.sqlskills.com/BLOGS/PAUL/post/Inside-the-Storage-Engine-Anatomy-of-a-page.aspx

但是我們可以查到如下信息:

m_type=17的這個數據類型ML map page,是在“大容量日志”模式下,記錄自上次備份以來哪些區被更改過,該頁第一個位置總是在每個文件的第7頁上,我們折回上面第一個查詢時的第三行,即PageType是ML_MAP_PAGE的那行,

并將其帶入如下SQL查詢出pageID的記錄:

發現這才是傳說中的那個第一頁總是出現在每個文件第7頁的混蛋!

我們將PageID7帶入DBCC PAGE:

Oh,SHIT!這個的m_type是17!

好吧,我只能說,是我曲解了人家字面的意思,原來:

BCM ,大容量更改映射(Bulk Change Map),在數據庫緩存中對應的PageType竟然是ML_MAP_PAGE!Minimally-Logged Page!

而那個該死的BULK_OPERATION_PAGE(m_type=20)是什么東西,誰能告訴我?

另外那個UNLINKED_REORG_PAGE,應該就是排序頁吧?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 特克斯县| 枣阳市| 沈丘县| 和龙市| 安阳县| 盱眙县| 南安市| 克什克腾旗| 乡宁县| 罗甸县| 绥化市| 汉沽区| 姜堰市| 太仓市| 浑源县| 阜新| 思南县| 武汉市| 峨边| 淅川县| 鞍山市| 清远市| 万全县| 文登市| 惠水县| 阳江市| 志丹县| 通道| 盐亭县| 南宁市| 新邵县| 马山县| 赤城县| 阳新县| 皮山县| 莱西市| 柳州市| 德安县| 台前县| 阿尔山市| 丹巴县|