SQL優化:合理使用變量
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
新手小伙伴平時可能比較少用到變量,其實變量在數據查詢過程中經常使用到,而且可以有效提高查詢速度。 變量其實就是我們定義的一個可變參數,其基本語法如下:
使用變量后,相同的查詢語句如果只是賦值不同,可以重復使用第一次的執行計劃,做到一次解析,多次復用的效果,減少執行計劃的解析就會相應提高查詢速度了。我們看如下示例:
如果單獨執行這兩條查詢語句,查詢優化器認為是不同的SQL語句,需要解析兩次。 我們使用變量對其進行修改
執行完之后,只需要修改@ORDER_ID的值為'113’,就可以重復使用上面的執行計劃了。 由于上面的語句比較簡單,可能看不出效果,但是如果遇到比較復雜的查詢語句,變量查詢往往能起到很好的效果。
事物都存在兩面性,變量對常見查詢可以提高查詢效率。但是也有例外,比如在WHERE條件中的字段是“傾斜字段”的時候。 “傾斜字段”指該列中的絕大多數的值都是相同的,比如人口調查表,其中“民族”這列,90%以上都是漢族。那么如果一個SQL語句要查詢30歲的漢族人口有多少,那“民族”這列必然要被放在WHERE條件中。這個時候如果采用綁定變量@NATION會存在很大問題。 如果@NATION傳入的第一個值是“漢族”,那整個執行計劃必然會選擇表掃描。
當第二個值傳入的是“畬族”,正常情況下“畬族”在表中占的比例可能只有萬分之一,應該采用索引查找。
由于重用了第一次解析的“漢族”的那個執行計劃,那么第二次也將采用表掃描方式。這個問題就是著名的“變量窺測”,建議對于“傾斜字段”不要采用綁定變量。 今天的課就講到這里,如果對變量還有什么不明白的,可以在底下留言,我會一一回復的。 閱讀原文:原文鏈接 該文章在 2025/6/23 12:57:24 編輯過 |
關鍵字查詢
相關文章
正在查詢... |