濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL Server 索引結構及其使用(二) 改善SQL語句第1/3頁

SQL Server 索引結構及其使用(二) 改善SQL語句第1/3頁

熱門標簽:電銷機器人公司 需要哪些牌照 廣東防封卡外呼系統原理是什么 長沙智能外呼系統 地圖標注牌 菏澤語音電銷機器人加盟公司 分享百度地圖標注多個位置 湖南電腦外呼系統平臺 知名電銷機器人價格 外呼系統改進
比如:
select * from table1 where name=''zhangsan'' and tID > 10000
和執(zhí)行:
select * from table1 where tID > 10000 and name=''zhangsan''   
一些人不知道以上兩條語句的執(zhí)行效率是否一樣,因為如果簡單的從語句先后上看,這兩個語句的確是不一樣,如果tID是一個聚合索引,那么后一句僅僅從表的10000條以后的記錄中查找就行了;而前一句則要先從全表中查找看有幾個name=''zhangsan''的,而后再根據限制條件條件tID>10000來提出查詢結果。

  事實上,這樣的擔心是不必要的。SQL SERVER中有一個“查詢分析優(yōu)化器”,它可以計算出where子句中的搜索條件并確定哪個索引能縮小表掃描的搜索空間,也就是說,它能實現自動優(yōu)化。

  雖然查詢優(yōu)化器可以根據where子句自動的進行查詢優(yōu)化,但大家仍然有必要了解一下“查詢優(yōu)化器”的工作原理,如非這樣,有時查詢優(yōu)化器就會不按照您的本意進行快速查詢。

  在查詢分析階段,查詢優(yōu)化器查看查詢的每個階段并決定限制需要掃描的數據量是否有用。如果一個階段可以被用作一個掃描參數(SARG),那么就稱之為可優(yōu)化的,并且可以利用索引快速獲得所需數據。

  SARG的定義:用于限制搜索的一個操作,因為它通常是指一個特定的匹配,一個值得范圍內的匹配或者兩個以上條件的AND連接。形式如下:
列名 操作符 常數 或 變量>



常數 或 變量> 操作符列名
列名可以出現在操作符的一邊,而常數或變量出現在操作符的另一邊。如:
Name='張三'

價格>5000

5000價格

Name='張三' and 價格>5000
  如果一個表達式不能滿足SARG的形式,那它就無法限制搜索的范圍了,也就是SQL SERVER必須對每一行都判斷它是否滿足WHERE子句中的所有條件。所以一個索引對于不滿足SARG形式的表達式來說是無用的。

  介紹完SARG后,我們來總結一下使用SARG以及在實踐中遇到的和某些資料上結論不同的經驗:

1、Like語句是否屬于SARG取決于所使用的通配符的類型
如:name like ‘張%' ,這就屬于SARG

而:name like ‘%張' ,就不屬于SARG。
原因是通配符%在字符串的開通使得索引無法使用。

2、or 會引起全表掃描
  Name='張三' and 價格>5000 符號SARG,而:Name='張三' or 價格>5000 則不符合SARG。使用or會引起全表掃描。
3、非操作符、函數引起的不滿足SARG形式的語句
  不滿足SARG形式的語句最典型的情況就是包括非操作符的語句,如:NOT、!=、>、!、!>、NOT EXISTS、NOT IN、NOT LIKE等,另外還有函數。下面就是幾個不滿足SARG形式的例子:
ABS(價格)5000

Name like ‘%三'

有些表達式,如:

WHERE 價格*2>5000

SQL SERVER也會認為是SARG,SQL SERVER會將此式轉化為:
WHERE 價格>2500/2
但我們不推薦這樣使用,因為有時SQL SERVER不能保證這種轉化與原始表達式是完全等價的。

4、IN 的作用相當與OR
語句:
Select * from table1 where tid in (2,3)



Select * from table1 where tid=2 or tid=3
是一樣的,都會引起全表掃描,如果tid上有索引,其索引也會失效。
123下一頁閱讀全文

標簽:西寧 珠海 天水 商洛 泉州 美容院 福建 呼和浩特

巨人網絡通訊聲明:本文標題《SQL Server 索引結構及其使用(二) 改善SQL語句第1/3頁》,本文關鍵詞  SQL,Server,索引,結構,及其,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server 索引結構及其使用(二) 改善SQL語句第1/3頁》相關的同類信息!
  • 本頁收集關于SQL Server 索引結構及其使用(二) 改善SQL語句第1/3頁的相關信息資訊供網民參考!
  • 推薦文章
    昌平区| 元阳县| 东至县| 和硕县| 小金县| 芒康县| 将乐县| 当阳市| 南城县| 原阳县| 赤城县| 邹平县| 盐池县| 内黄县| 图木舒克市| 阜宁县| 青海省| 黄浦区| 益阳市| 彭水| 嘉荫县| 云南省| 沧源| 中阳县| 水城县| 宜川县| 怀仁县| 大洼县| 鄂尔多斯市| 灯塔市| 浏阳市| 福清市| 泗水县| 榆树市| 抚州市| 六盘水市| 沐川县| 高邮市| 县级市| 体育| 秦皇岛市|