成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server索引密度的實際操作

數(shù)據(jù)庫 SQL Server
我們今天主要向大家講述的是SQL Server索引密度(Index Densities),以及對其實際操作中要用到的代碼描述。以下就是正文的主要內(nèi)容描述。

以下的文章主要向大家描述的是SQL Server索引密度(Index Densities),在實際操作中當(dāng)一個查詢的SARG 的值直到查詢運行時才已知,或是 SARG 是關(guān)于一個索引的多列時,SQL Server才使用為索引中每列存儲的密度值。

對于組合鍵值,SQL Server為第一列的組合鍵存儲了密度值;為第一列和第二列;為第一、二、三列;等等。這些信息可以從Listing34.1的DBCC SHOW_STATISTICS 輸出信息的All density區(qū)域看到。

SQL Server索引密度表示為鍵的唯一鍵值的倒數(shù)。每個鍵的密度可以按照下面的公式進行計算:

 

 

引用

 

 

  1. Key density = 1.00/ ( Count of distinct key values in the table)  

 

鍵密度 = 1.00 / (表中的不同鍵值數(shù))

 

 

所以,pubs數(shù)據(jù)庫的author表中state列的密度計算公式如下:

 

 

  1. Sql代碼   
  2. Select Density = 1.00/ (select count (distinct state) from authors)   
  3. Go   
  4. Select Density = 1.00/ (select count (distinct state) from authors)  
  5. Go  
  6. Density   
  7. .1250000000000   
  8.  

State和zip的組合列密度計算如下:

  1. Sql代碼   
  2. Select density = 1.00/( select count (distinct state + zip) from authors)   
  3. Go   
  4. Select density = 1.00/( select count (distinct state + zip) from authors)  
  5. Go  
  6. Density   
  7. .0555555555555   
  8.  

注意,不像選擇率,越小的SQL Server索引密度意味著具有更高的索引選擇性。當(dāng)密度趨近于1,索引就變得有更少的選擇性,基本上沒有用處了。當(dāng)索引的選擇性低的時候,優(yōu)化器可能會選擇一個表掃描(table scan),或者葉子級的索引掃描(Index scan),而不會進行索引查找(index seek),因為這樣會付出更多的代價。

 

引用

 

提示:

 

當(dāng)心你的數(shù)據(jù)庫中低選擇性的索引。這樣的索引通常是對系統(tǒng)的性能是一個損害。它們通常不僅不會用來進行數(shù)據(jù)的檢索,而且也會使得數(shù)據(jù)修改語句變得緩慢,因為需要額外的索引維護。識別這些索引,考慮刪除掉它們。

 

通常,當(dāng)你給鍵中添加更多的列時,密度值應(yīng)該變得更小。例如,在Listing 34.2,密度值逐漸變小。

 

 

  1. Key Column Index Density   
  2. title_id 1.8621974E-3   
  3. title_id, stor_id 5.997505E-6   
  4. title_id, stor_id, ord_num 5.9268041E-6  

使用索引密度評估行數(shù)(Estimating Rows Using the Index Statistics)

那么優(yōu)化器是如何使用SQL Server索引密度來決定一個索引的效果呢?

當(dāng)在一個范圍內(nèi)查找一個索引值或者鍵中存在重復(fù)值時,SQL Server會使用直方圖信息。考慮下面關(guān)于bigpubs2000數(shù)據(jù)庫中的sales表中查詢:

 

Sql代碼

 

  1. Select * from sales   
  2. Where title_id = 'BI2184'   
  3. Select * from sales  
  4. Where title_id = 'BI2184' 

因為在表中title_id中存在重復(fù)值,SQL Server使用關(guān)于title_id的直方圖(參考Listing34.2)來估計匹配的行數(shù)。對于BI2184值,它將查看EQ_ROWS值,值為343.0。這表示在表中title_id值為BI2184的記錄共有343行。

當(dāng)一個查詢參數(shù)(search argument)的精確匹配(exact match 即等號計算)在直方圖中step沒有發(fā)現(xiàn)時,SQL Server使用比查找值(search value)大的下一個step中的AVG_RANG_ROWS值。例如,SQL Server對查找值為‘BI2187’進行評估,它將會發(fā)現(xiàn)匹配值為270.0行。

對一個范圍檢索,SQL Server把檢范圍兩端的RANG_ROW和EQ_ROWS相加。例如,利用Listing34.2中的直方圖,如果查找參數(shù)為 where title_id <= 'BI2574',行數(shù)估計將是:

314 + 613 + 343 + 270 + 277,或者為1817。

 

當(dāng)直方圖不能使用時,SQL Server就使用索引密度來估計匹配行數(shù)。對于等值查找的計算公式是直截了當(dāng)?shù)模纾?/p>

  1. Sql代碼   
  2. Declare @tid varchar(6)   
  3. Select @tid = 'BI2574'   
  4. Select count(*) from sales where title_id = @tid   
  5. Declare @tid varchar(6)  
  6. Select @tid = 'BI2574' 
  7. Select count(*) from sales where title_id = @tid  

 

行估計值等于指定鍵值的SQL Server索引密度(1.8621974E-3)乘以表中行數(shù):

  1. Sql代碼   
  2. Select count(*) * 1.8621974E-3   
  3. From sales   
  4. Go   
  5. Select count(*) * 1.8621974E-3  
  6. From sales  
  7. Go  
  8. 314.19925631500001   

如果一個查詢的SARG為title_id 和stor_id,并且假如title_id的SARG是一個可在優(yōu)化期間可評價的常量表達式,SQL Server會用title_id stor_id的索引密度和title_id的直方圖來估計匹配的行數(shù)(對某些值來說,索引密度估計的值可能會大學(xué)直方圖估計出來的值)。SQL Server 將會用二者中較小的值作為匹配的行數(shù)。

根據(jù)title_id stor_id的索引密度,你能看到:

  1. Sql代碼   
  2. Select coun(*) * 5.997505E-6   
  3. From sales   
  4. Select coun(*) * 5.997505E-6  
  5. From sales  
  6. 1.011929031125   

 

在這個例子中,SQL Server將用title_id 和stor_id的SQL Server索引密度來估計匹配的值。在此情況下,它估計查詢將返回一條匹配的行。

【編輯推薦】

  1. 優(yōu)化SQL Server數(shù)據(jù)庫的經(jīng)驗大盤點
  2. SQL Server 2005商業(yè)智能功能淺析
  3. 修改SQL Server 2005 數(shù)據(jù)庫的執(zhí)行環(huán)境很簡單
  4. SQL Server 2000數(shù)據(jù)庫備份和還原的示例
  5. SQL Server 2008數(shù)據(jù)庫在實際應(yīng)用中的獨到之處
責(zé)任編輯:佚名 來源: 重慶晨報
相關(guān)推薦

2010-06-17 12:26:51

SQL Server索

2010-07-21 15:22:07

2010-07-02 12:51:35

SQL Server

2010-06-28 12:39:14

SQL Server數(shù)

2010-07-16 11:10:52

SQL server

2010-07-23 09:25:50

SQL Server導(dǎo)

2010-04-20 11:06:33

Oracle索引

2010-06-28 12:27:35

SQL Server

2010-06-30 17:56:06

2010-06-28 13:27:33

SQL Server視

2010-07-05 12:21:57

SQL Server記

2010-07-12 10:13:44

SQL Server表

2010-07-06 09:20:30

SQL Server查

2010-06-18 08:30:48

SQL Server

2010-07-02 11:10:56

SQL Server

2010-07-23 14:26:37

SQL Server存

2010-04-16 17:17:31

Oracle訪問

2010-07-05 10:15:40

SQL Server

2010-07-20 11:13:09

SQL Server日

2010-07-21 09:28:34

SQL Server
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 成人高清视频在线观看 | 中文字幕一二三区 | www久久av | 国产成人精品一区二区 | 久久久久国产一区二区三区 | 狠狠爱免费视频 | 国产成人精品一区二区三 | 精品国产91乱码一区二区三区 | 91成人免费看片 | 亚洲视频一区在线观看 | 国产日韩欧美中文字幕 | 国产婷婷精品 | 欧美xxxⅹ性欧美大片 | 羞羞视频网站免费看 | 午夜影院| 九九热在线视频观看这里只有精品 | 99成人精品 | 欧美中文字幕一区二区三区亚洲 | 色888www视频在线观看 | 又爽又黄axxx片免费观看 | 高清18麻豆 | 国产在线一区二区三区 | 午夜精品久久久 | 久久国产精品免费一区二区三区 | 午夜免费网站 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 翔田千里一区二区 | 国产精品久久久久久影院8一贰佰 | 91se在线 | 999精品视频 | 久久一二区 | 噜噜噜噜狠狠狠7777视频 | 精品在线一区二区 | 人人看人人干 | 国产精品视频免费观看 | 日日骚网 | 日韩在线 | 精品欧美一区二区久久久伦 | 一区二区三区欧美在线观看 | 中文字幕一区二区三区四区五区 | 亚洲精品视频在线看 |