SQLSERVER中忽略索引提示

2022-09-24 10:21:15 字數 1732 閱讀 5924

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

複製** **如下:

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

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

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

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

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

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

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

複製** **如下:

use master

goif db_id('trace8602') is not null

drop database trace8602

gocreate database trace8602

gouse trace8602

gocreate table xttrace8602

(id int identity(1, 1)

&nyziremadbsp;   primary key ,

bal int ,

程式設計客棧;   www.cppcns.com; name varchar(100)

)gocreate nonc程式設計客棧lustered index ix_xttrace8602_bal_name on xttrace8602(bal,name)

go現在執行下面**

複製** **如下:

--沒有使用跟蹤標緻

exec uspfirst 

go複製** **如下:

--使用了跟蹤標誌

dbcc traceon(8602,-1)

godbcc freeproccache

goexec uspfirst

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

而不需要額外的鍵查詢

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

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

如有不對的地方,歡迎大家拍磚o(∩_∩)o

本文標題: sqlserver中忽略索引提示

本文位址:

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中如何忽略索引提示

原文 sqlserver中如何忽略索引提示 當我們想讓某條查詢語句利用某個索引的時候,我們一般會在查詢語句裡加索引提示,就像這樣 select id,name from tb with index ix xttrace bal where bal 100當在生產環境裡面,由於這個索引提示的原因,優化...