校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > SQL Server誤區30日談 第6天 有關NULL位圖的三個誤區

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

熱門標簽:400電話申請需要開戶費嗎 北京辦理400電話多少 智能語音外呼系統哪個牌子好 山西語音外呼系統價格 威海智能語音外呼系統 重慶防封電銷機器人供應商 溫州語音外呼系統代理 南京電銷外呼系統運營商 西安青牛防封電銷卡
這樣還能減少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.
您可能感興趣的文章:
  • 使用jQueryMobile實現滑動翻頁效果的方法
  • jquery實現圖片翻頁效果
  • jquery實現的點擊翻書效果代碼
  • jQuery實現手機版頁面翻頁效果的簡單實例

標簽:宜春 濟寧 中衛 金昌 貸款群呼 河源 黃山 新余

巨人網絡通訊聲明:本文標題《SQL Server誤區30日談 第6天 有關NULL位圖的三個誤區》,本文關鍵詞  SQL,Server,誤區,30日談,第,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server誤區30日談 第6天 有關NULL位圖的三個誤區》相關的同類信息!
  • 本頁收集關于SQL Server誤區30日談 第6天 有關NULL位圖的三個誤區的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 福清市| 嘉兴市| 定陶县| 桃江县| 桑日县| 丹寨县| 修武县| 台湾省| 昌宁县| 密云县| 桐城市| 嘉鱼县| 梓潼县| 陇西县| 永昌县| 章丘市| 来凤县| 盐池县| 离岛区| 宝兴县| 崇义县| 阿拉尔市| 慈利县| 五原县| 南充市| 介休市| 云龙县| 磴口县| 大竹县| 铜川市| 河北区| 乌拉特前旗| 胶州市| 嘉祥县| 忻城县| 英山县| 乐陵市| 仲巴县| 定远县| 东港市| 合阳县|