SQLSERVER中如何忽略索引提示

2021-09-06 19:33:23 字數 2044 閱讀 6529

原文:

sqlserver中如何忽略索引提示

當我們想讓某條查詢語句利用某個索引的時候,我們一般會在查詢語句裡加索引提示,就像這樣

select  id,name from tb  with (index(ix_xttrace_bal)) where bal<

100

當在生產環境裡面,由於這個索引提示的原因,優化器一般不會再去考慮其他的索引,那有時候這個索引提示可能會導致查詢變慢

經過你的測試,發現確實是因為這個索引提示的關係導致查詢變慢,但是sql伺服器已經快取了這條sql語句的執行計畫,如果修改sql語句的話可能會有影響

而且,可能不單只一條sql語句用了索引提示,還有其他的sql語句也用了索引提示,你不可能馬上去修改這些sql語句的時候可以使用sqlserver裡面的乙個trace flag

這個trace flag能忽略sql語句裡面的索引提示和儲存過程裡面的索引提示

不需要修改sql語句,就可以進行效能排查

執行下面指令碼建立資料庫和相關索引

現在執行下面**

--

沒有使用跟蹤標緻

使用了跟蹤標誌

可以看到,開啟traceon(8602,-1) 跟蹤標誌之後,sqlserver忽略了索引提示,利用復合索引ix_xttrace8602_bal_name 把資料查出來

而不需要額外的鍵查詢

這個跟蹤標誌不需要你修改你的sql語句就可以讓sqlserver忽略索引提示

在使用這個8602跟蹤標誌之前記得先在開發環境測試好,確認是否需要忽略索引提示,以便做成效能問題

SQLSERVER中如何忽略索引提示

當我們想讓某條查詢語句利用某個索引的時候,我們一般會在查詢語句裡加索引提示,就像這樣 select id,name from tb with index ix xttrace bal where bal 100 當在生產環境裡面,由於這個索引提示的原因,優化器一般不會再去考慮其他的索引,那有時候這個...

SQLSERVER中如何忽略索引提示

當我們想讓某條查詢語句利用某個索引的時候,我們一般會在查詢語句裡加索引提示,就像這樣 select id,name from tb with index ix xttrace bal where bal 100當在生產環境裡面,由於這個索引提示的原因,優化器一般不會再去考慮其他的索引,那有時候這個索...

SQLSERVER中如何忽略索引提示

當我們想讓某條查詢語句利用某個索引的時候,我們一般會在查詢語句裡加索引提示,就像這樣 select id,name from tb with index ix xttrace bal where bal 100當在生產環境裡面,由於這個索引提示的原因,優化器一般不會再去考慮其他的索引,那有時候這個索...