濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server2014 哈希索引原理詳解

SQL Server2014 哈希索引原理詳解

熱門標(biāo)簽:南京怎么申請400這種電話 濮陽清豐400開頭的電話申請 地圖標(biāo)注跑線下市場 樂昌電話機(jī)器人 疫情時(shí)期電話機(jī)器人 臺灣外呼系統(tǒng)軟件 真3地圖標(biāo)注 地圖標(biāo)注可以編輯地名嗎 南通智能外呼系統(tǒng)怎么樣

當(dāng)一個(gè)key-value鍵值對傳遞給一個(gè)哈希函數(shù)的時(shí)候,經(jīng)過哈希函數(shù)的計(jì)算之后,根據(jù)結(jié)果會(huì)把key-value鍵值對放在合適的hash buckets(哈希存儲桶)里

舉個(gè)栗子

我們假設(shè)對10取模( % 10 )就是哈希函數(shù)。如果key-value鍵值對的key是1525 ,傳遞到哈希函數(shù),那么1525 會(huì)存放在第五個(gè)bucket里

因?yàn)? as 1525 % 10 = 5。

同樣,537 會(huì)存放在第七個(gè)bucket ,2982 會(huì)存放在第二個(gè)bucket ,依次類推

同樣,在hash index里面,哈希索引列會(huì)被傳遞給哈希函數(shù)做匹配(類似于java里面的HashMap的Map操作),匹配成功之后,

索引列會(huì)被存儲在匹配到的hash bucket里面的表里,這個(gè)表里會(huì)有實(shí)際的數(shù)據(jù)行指針,再根據(jù)實(shí)際的數(shù)據(jù)行指針查找對應(yīng)的數(shù)據(jù)行。

概括來說,要查找一行數(shù)據(jù)或者處理一個(gè)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)樹索引簡單,因?yàn)樗恍枰闅vB樹,所以訪問速度會(huì)更快

 

哈希函數(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)建完之后添加哈希索引,不過

添加哈希索引是一個(gè)離線操作。

哈希索引的Bucket 數(shù)量

( BUCKET_COUNT = 100000 )定義了哈希索引能夠使用的BUCKET數(shù)量,這個(gè)Bucket 是固定的并且由用戶指定Bucket 數(shù)量,

而不是執(zhí)行查詢的時(shí)候由SQL Server決定生成的Bucket 數(shù)量。BUCKET數(shù)量總是2的次方的四舍五入( 1024, 2048, 4096 etc..)

SQL Server2014的哈希索引其實(shí)跟MySQL的自適應(yīng)哈希索引原理其實(shí)差不多,都是為了擺脫B樹的束縛,使查找效率更快

How does a relational database work這篇文章也有描述hash join的原理,大家可以看一下

您可能感興趣的文章:
  • sqlserver索引的原理及索引建立的注意事項(xiàng)小結(jié)
  • SqlServer索引的原理與應(yīng)用詳解
  • SQL Server 索引介紹
  • SQLSERVER全文目錄全文索引的使用方法和區(qū)別講解
  • SQL Server 聚集索引和非聚集索引的區(qū)別分析
  • SQLSERVER 創(chuàng)建索引實(shí)現(xiàn)代碼
  • SQLSERVER聚集索引和主鍵(Primary Key)的誤區(qū)認(rèn)識
  • sqlserver 索引的一些總結(jié)
  • SQL Server全文索引服務(wù)
  • SQL Server索引的原理深入解析

標(biāo)簽:阿里 陜西 河北 馬鞍山 廣安 南京 福建 通遼

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL Server2014 哈希索引原理詳解》,本文關(guān)鍵詞  SQL,Server2014,哈希,索引,原理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL Server2014 哈希索引原理詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL Server2014 哈希索引原理詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    双辽市| 大田县| 桦甸市| 通江县| 昭觉县| 金堂县| 康平县| 阜平县| 临夏市| 凭祥市| 和硕县| 新龙县| 永泰县| 东光县| 桂平市| 改则县| 廊坊市| 陆河县| 东乡| 朝阳市| 余干县| 博湖县| 沿河| 邢台县| 论坛| 法库县| 扎鲁特旗| 浑源县| 涿州市| 兴和县| 六盘水市| 察隅县| 长沙市| 阿拉善右旗| 微山县| 乌兰浩特市| 河西区| 凌源市| 浦城县| 鹰潭市| 南昌市|