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

溫馨提示×

溫馨提示×

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

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

如何使用變量對SQL進行優化

發布時間:2021-06-26 14:36:33 來源:億速云 閱讀:114 作者:chen 欄目:數據庫

這篇文章主要介紹“如何使用變量對SQL進行優化”,在日常操作中,相信很多人在如何使用變量對SQL進行優化問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何使用變量對SQL進行優化”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

 1.什么是變量

變量其實就是我們定義的一個可變參數,其基本語法如下:

--定義一個名稱為@I的變量,指定其類型為整數

DECLARE @I VARCHAR(20)

--對變量@I賦值為

SET @I='SQL數據庫開發'

--輸出@I的值

SELECT @I

結果:SQL數據庫開發

  • 其中DECLARE @部分是固定寫法,@I是變量名稱,變量必須定義類型,一般會定義為字符型,整數型,時間類型等。

  • 賦值部分SET也是固定寫法,就是對變量@I進行賦值,=右邊的就是賦值內容了

  • 定義好變量后就可以將其帶入到查詢語句中了,每次只需要修改賦值部分,查詢語句就會根據賦值內容查詢出相應的結果

2.為什么要使用變量

使用變量后,相同的查詢語句如果只是賦值不同,可以重復使用第一次的執行計劃,做到一次解析,多次復用的效果,減少執行計劃的解析就會相應提高查詢速度了。我們看如下示例:

SELECT * FROM T1 WHERE ORDER_ID='112'; SELECT * FROM T1 WHERE ORDER_ID='113';

如果單獨執行這兩條查詢語句,查詢優化器認為是不同的SQL語句,需要解析兩次。我們使用變量對其進行修改

DECLARE @ORDER_ID VARCHAR(20) SET @ORDER_ID='112' SELECT * FROM T1 WHERE ORDER_ID=@ORDER_ID;

執行完之后,只需要修改@ORDER_ID的值為'113’,就可以重復使用上面的執行計劃了。由于上面的語句比較簡單,可能看不出效果,但是如果遇到比較復雜的查詢語句,變量查詢往往能起到很好的效果。

3.什么時候該/不該使用變量

  • 常見的在線查詢一遍都可以使用到變量,將變量作為參數傳遞給數據庫,可以實現一次查詢,重復使用執行計劃。

  • 如果單獨查詢某個語句時間很久,比如超過半個小時了,這種使用變量沒有什么明顯的效果。

4變量窺測

事物都存在兩面性,變量對常見查詢可以提高查詢效率。但是也有例外,比如在WHERE條件中的字段是“傾斜字段”的時候。

“傾斜字段”指該列中的絕大多數的值都是相同的,比如人口調查表,其中“民族”這列,90%以上都是漢族。那么如果一個SQL語句要查詢30歲的漢族人口有多少,那“民族”這列必然要被放在WHERE條件中。這個時候如果采用綁定變量@NATION會存在很大問題。

如果@NATION傳入的第一個值是“漢族”,那整個執行計劃必然會選擇表掃描。

DECLARE @NATION VARCHAR(50)  SET @NATION='漢族'  SELECT * FROM People WHERE AGE=30 AND NATION=@NATION;

當第二個值傳入的是“畬族”,正常情況下“畬族”在表中占的比例可能只有萬分之一,應該采用索引查找。

DECLARE @NATION VARCHAR(50)  SET @NATION='畬族'  SELECT * FROM People WHERE AGE=30 AND NATION=@NATION;

由于重用了第一次解析的“漢族”的那個執行計劃,那么第二次也將采用表掃描方式。這個問題就是著名的“變量窺測”,建議對于“傾斜字段”不要采用綁定變量。

到此,關于“如何使用變量對SQL進行優化”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

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

sql
AI

庐江县| 武宣县| 惠来县| SHOW| 大港区| 无为县| 丰镇市| 山丹县| 通城县| 开鲁县| 民权县| 宜兰市| 闵行区| 湖北省| 洱源县| 水富县| 乌兰浩特市| 屏东县| 库尔勒市| 闵行区| 荥阳市| 罗山县| 高淳县| 奉新县| 绥芬河市| 汕头市| 望江县| 安徽省| 育儿| 察雅县| 洪湖市| 沈阳市| 两当县| 远安县| 克拉玛依市| 合水县| 义乌市| 拉萨市| 商都县| 皋兰县| 重庆市|