亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SQLSERVER中怎么忽略索引提示

發布時間:2021-08-13 15:56:17 來源:億速云 閱讀:156 作者:Leah 欄目:數據庫

今天就跟大家聊聊有關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語句,就可以進行性能排查

運行下面腳本創建數據庫和相關索引

復制代碼 代碼如下: USE masterGOIF DB_ID('Trace8602') IS NOT NULL DROP DATABASE Trace8602GOCREATE DATABASE Trace8602GOUSE Trace8602GOCREATE TABLE xttrace8602 ( id INT IDENTITY(1, 1) PRIMARY KEY , bal INT , name VARCHAR(100) )GOCREATE NONCLUSTERED INDEX IX_xttrace8602_bal_name ON xttrace8602(bal,name)GOCREATE NONCLUSTERED INDEX IX_xttrace8602_bal ON xttrace8602(bal)GOINSERT INTO xttrace8602VALUES ( RAND() * 786, 'cnblogs.com/lyhabc' )GO 10000CREATE PROC uspFirstAS SELECT id , name FROM xttrace8602 TF WITH ( INDEX ( IX_xttrace8602_bal ) ) WHERE bal < 100GO

現在執行下面代碼

復制代碼 代碼如下: --沒有使用跟蹤標致EXEC uspFirst GO

復制代碼 代碼如下: --使用了跟蹤標志DBCC TRACEON(8602,-1)GODBCC FREEPROCCACHEGOEXEC uspFirst GO

可以看到,打開TRACEON(8602,-1) 跟蹤標志之后,SQLSERVER忽略了索引提示,利用復合索引IX_xttrace8602_bal_name 把數據查出來

而不需要額外的鍵查找

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

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

看完上述內容,你們對SQLSERVER中怎么忽略索引提示有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

天台县| 台南市| 大渡口区| 陈巴尔虎旗| 枣庄市| 郓城县| 蒲江县| 年辖:市辖区| 额济纳旗| 阿克| 丰都县| 贵定县| 繁昌县| 库尔勒市| 阿图什市| 开平市| 伊春市| 巴南区| 延吉市| 安新县| 麻城市| 和田县| 手游| 弋阳县| 天峨县| 习水县| 阿坝| 凤城市| 邳州市| 阿尔山市| 南昌市| 固镇县| 葵青区| 中方县| 广州市| 石台县| 佛学| 大荔县| 昆山市| 都匀市| 西乌珠穆沁旗|