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

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

SQL Server誤區30日談 第6天 有關NULL位圖的三個誤區

2024-08-31 00:56:48
字體:
來源:轉載
供稿:網友
這樣還能減少CPU緩存命中失效的問題(點擊這個鏈接來查看CPU的緩存是如何工作的以及MESI協議)。下面讓我們來揭穿三個有關NULL位圖的普遍誤區。

誤區 #6a:NULL位圖并不是任何時候都會用到

正確

就算表中不存在允許NULL的列,NULL位圖對于數據行來說會一直存在(數據行指的是堆或是聚集索引的葉子節點)。但對于索引行來說(所謂的索引行也就是聚集索引和非聚集索引的非葉子節點以及非聚集索引的葉子節點)NULL位圖就不是一直有效了。

下面這條語句可以有效的證明這一點:

復制代碼 代碼如下:


CREATE TABLE NullTest (c1 INT NOT NULL);
CREATE NONCLUSTERED INDEX
NullTest_NC ON NullTest (c1);
GO
INSERT INTO NullTest VALUES (1);
GO
EXEC sp_allocationMetadata 'NullTest';
GO


你可以通過我的博文:Inside The Storage Engine: sp_AllocationMetadata - putting undocumented system catalog views to work.來獲得sp_allocationMetadata 的實現腳本。

讓我們通過下面的script來分別查看在堆上的頁和非聚集索引上的頁:

復制代碼 代碼如下:


DBCC TRACEON (3604);
DBCC PAGE (foo, 1, 152, 3); -- page ID from SP output
where Index ID = 0
DBCC PAGE (foo, 1, 154, 1); -- page ID from SP output
where Index ID = 2
GO


首先讓我們來看堆上這頁Dump出來的結果

復制代碼 代碼如下:


Slot 0 Offset 0x60 Length 11
Record Type = PRIMARY_RECORD Record Attributes = NULL_BITMAP Memory Dump
@0x685DC060



再來看非聚集索引上的一頁Dump出來的結果:

復制代碼 代碼如下:


Slot 0, Offset 0x60, Length 13, DumpStyle BYTE
Record Type = INDEX_RECORD Record Attributes = <<<<<<<
No null bitmap Memory Dump @0x685DC060



誤區 #6b: NULL位圖僅僅被用于可空列

錯誤

當NULL位圖存在時,NULL位圖會給記錄中的每一列對應一位,但是數據庫中最小的單位是字節,所以為了向上取整到字節,NULL位圖的位數可能會比列數要多。對于這個問題.我已經有一篇博文對此進行概述,請看:Misconceptions around null bitmap size.

誤區 #6c:給表中添加額外一列時會立即導致SQL Server對表中數據的修改

錯誤

只有向表中新添加的列是帶默認值,且默認值不是NULL時,才會立即導致SQL Server對數據條目進行修改。總之,SQL Server存儲引擎會記錄一個或多個新添加的列并沒有反映在數據記錄中。關于這點,我有一篇博文更加深入的對此進行了闡述:Misconceptions around adding columns to a table.
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 忻城县| 福海县| 沐川县| 东丰县| 甘南县| 海盐县| 手机| 偏关县| 泽普县| 来安县| 东港市| 冕宁县| 中方县| 天峻县| 阜新| 北京市| 彝良县| 民丰县| 于田县| 宜章县| 娄底市| 抚宁县| 安溪县| 南投市| 古蔺县| 贺兰县| 遵化市| 三都| 固原市| 本溪| 泾源县| 宜君县| 交城县| 临城县| 安顺市| 泗洪县| 房山区| 商都县| 崇仁县| 勐海县| 芜湖市|