SQL Server2014 哈希索引原理詳解
當(dāng)一個key-value鍵值對傳遞給一個哈希函數(shù)的時候,經(jīng)過哈希函數(shù)的計算之后,根據(jù)結(jié)果會把key-value鍵值對放在合適的hash buckets(哈希存儲桶)里
舉個栗子
我們假設(shè)對10取模( % 10 )就是哈希函數(shù)。如果key-value鍵值對的key是1525 ,傳遞到哈希函數(shù),那么1525 會存放在第五個bucket里
因為5 as 1525 % 10 = 5。
同樣,537 會存放在第七個bucket ,2982 會存放在第二個bucket ,依次類推
同樣,在hash index里面,哈希索引列會被傳遞給哈希函數(shù)做匹配(類似于java里面的HashMap的Map操作),匹配成功之后,
索引列會被存儲在匹配到的hash bucket里面的表里,這個表里會有實際的數(shù)據(jù)行指針,再根據(jù)實際的數(shù)據(jù)行指針查找對應(yīng)的數(shù)據(jù)行。
概括來說,要查找一行數(shù)據(jù)或者處理一個where子句,SQL Server引擎需要做下面幾件事
1、根據(jù)where條件里面的參數(shù)生成合適的哈希函數(shù)
2、索引列進(jìn)行匹配,匹配到對應(yīng)hash bucket,找到對應(yīng)hash bucket意味著也找到了對應(yīng)的數(shù)據(jù)行指針(row pointer)
3、讀取數(shù)據(jù)
哈希索引比起B(yǎng)樹索引簡單,因為它不需要遍歷B樹,所以訪問速度會更快

哈希函數(shù)和相應(yīng)語法的例子
CREATE TABLE dbo.HK_tbl
(
[ID] INT IDENTITY(1, 1)
NOT NULL
PRIMARY KEY NONCLUSTERED HASH WITH ( BUCKET_COUNT = 100000 ) ,
[Data] char(32) COLLATE Latin1_General_100_BIN2
NULL ,
[dt] datetime NOT NULL,
)
WITH (
MEMORY_OPTIMIZED =
ON,
DURABILITY =
SCHEMA_AND_DATA);
在SQL Server 2014里面,內(nèi)存優(yōu)化表創(chuàng)建完之后就不能再加哈希索引了,但是在 SQL Server 2016 里支持表創(chuàng)建完之后添加哈希索引,不過
添加哈希索引是一個離線操作。
哈希索引的Bucket 數(shù)量
( BUCKET_COUNT = 100000 )定義了哈希索引能夠使用的BUCKET數(shù)量,這個Bucket 是固定的并且由用戶指定Bucket 數(shù)量,
而不是執(zhí)行查詢的時候由SQL Server決定生成的Bucket 數(shù)量。BUCKET數(shù)量總是2的次方的四舍五入( 1024, 2048, 4096 etc..)
SQL Server2014的哈希索引其實跟MySQL的自適應(yīng)哈希索引原理其實差不多,都是為了擺脫B樹的束縛,使查找效率更快
How does a relational database work這篇文章也有描述hash join的原理,大家可以看一下


相關(guān)文章
SqlServer高版本數(shù)據(jù)備份還原到低版本
這篇文章主要為大家詳細(xì)介紹了SqlServer高版本數(shù)據(jù)備份還原到低版本的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
SQL Server 觸發(fā)器 表的特定字段更新時,觸發(fā)Update觸發(fā)器
另外再補充一句:insert和update的數(shù)據(jù)都會保存在臨時表中,所以使用inserted可以取出這些數(shù)據(jù),刪除時使用deleted可以取出被刪除的數(shù)據(jù)2009-08-08
深入淺出解析mssql在高頻,高并發(fā)訪問時鍵查找死鎖問題
SQL Server死鎖使我們經(jīng)常遇到的問題,數(shù)據(jù)庫操作的死鎖是不可避免的,本文并不打算討論死鎖如何產(chǎn)生,重點在于解決死鎖。希望對您學(xué)習(xí)SQL Server死鎖方面能有所幫助。2014-08-08
SQL SERVER 將XML變量轉(zhuǎn)為JSON文本
這篇文章主要介紹了SQL SERVER 將XML變量轉(zhuǎn)為JSON文本的相關(guān)資料,需要的朋友可以參考下2016-03-03
SQL Server中T-SQL 數(shù)據(jù)類型轉(zhuǎn)換詳解
T-SQL提供了兩個顯示轉(zhuǎn)換的函數(shù):CAST函數(shù)和CONVERT函數(shù)。今天我們就來相信探討下2018-02-02
sql語句查詢數(shù)據(jù)庫中的表名/列名/主鍵/自動增長值實例
sql語句查詢數(shù)據(jù)庫中的表名/列名/主鍵/自動增長值實例,需要的朋友可以參考下2012-06-06
SQLSERVER編譯與重編譯發(fā)生場景及重用的利弊介紹
本文將介紹編譯的含義;執(zhí)行計劃重用的利弊以及重編譯的發(fā)生場景等等,為您學(xué)習(xí)SQLSERVER編譯與重編譯打下很好的基礎(chǔ),感興趣的朋友可以了解下2013-01-01
SQLServer 數(shù)據(jù)庫的數(shù)據(jù)匯總完全解析(WITH ROLLUP)
乍一看,好像很容易,用group by好像能實現(xiàn)?但仔細(xì)研究下去,你又會覺得group by也是無能為力,總欠缺點什么,無從下手。那么,到底該如何做呢?別急,SQL Server早就幫我們做好了,下面,跟我來。2010-09-09

