成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用變量對 SQL 進行優化

數據庫 SQL Server
新手小伙伴平時可能比較少用到變量,其實變量在數據查詢過程中經常使用到,而且可以有效提高查詢速度。

 1.什么是變量

[[398270]]

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

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

DECLARE @I VARCHAR(20)

--對變量@I賦值為

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

--輸出@I的值

SELECT @I

結果:SQL數據庫開發

  • 其中DECLARE @部分是固定寫法,@I是變量名稱,變量必須定義類型,一般會定義為字符型,整數型,時間類型等。
  • 賦值部分SET也是固定寫法,就是對變量@I進行賦值,=右邊的就是賦值內容了
  • 定義好變量后就可以將其帶入到查詢語句中了,每次只需要修改賦值部分,查詢語句就會根據賦值內容查詢出相應的結果

2.為什么要使用變量

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

 

  1. SELECT * FROM T1 WHERE ORDER_ID='112'
  2. SELECT * FROM T1 WHERE ORDER_ID='113'

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

 

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

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

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

  • 常見的在線查詢一遍都可以使用到變量,將變量作為參數傳遞給數據庫,可以實現一次查詢,重復使用執行計劃。
  • 如果單獨查詢某個語句時間很久,比如超過半個小時了,這種使用變量沒有什么明顯的效果。

4變量窺測

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

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

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

 

  1. DECLARE @NATION VARCHAR(50) 
  2.  
  3. SET @NATION='漢族' 
  4.  
  5. SELECT * FROM People WHERE AGE=30 AND NATION=@NATION; 

 

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

 

  1. DECLARE @NATION VARCHAR(50) 
  2.  
  3. SET @NATION='畬族' 
  4.  
  5. SELECT * FROM People WHERE AGE=30 AND NATION=@NATION; 

 

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

責任編輯:華軒 來源: SQL數據庫開發
相關推薦

2023-07-13 11:24:14

SQL優化賦值

2010-04-19 17:09:30

Oracle sql

2010-07-08 17:40:27

2009-04-16 17:44:46

性能優化擴展高性能

2023-01-30 08:30:09

Tomcat性能優化

2010-07-14 09:17:17

SQL Server數

2018-04-19 15:13:53

javascriptwebpackvue.js

2010-07-22 17:25:23

2018-07-05 22:38:23

大數據搜索引擎SEO

2010-07-15 15:15:48

SQL Server使

2009-12-23 13:23:29

ADO.Net Sql

2010-05-17 17:09:29

Mysql LIMIT

2021-06-15 20:59:14

Kubernetes調試容器

2023-12-12 07:30:54

IstioWasm前端

2011-08-10 16:44:22

電腦老年人

2016-09-13 19:51:01

移動應用圖片流量優化

2010-03-01 18:01:45

Python環境變量

2010-12-14 11:30:11

2011-07-04 14:28:18

SQL Server分區

2009-10-22 09:32:51

ghostlinux系統備份
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91久久精品国产 | 天天躁日日躁狠狠很躁 | 91在线免费视频 | 九九综合 | 国产一级淫片a直接免费看 免费a网站 | www.精品一区| 久久91av | 亚洲国产精品久久 | 日韩视频一区二区 | 午夜精品三区 | av在线电影网站 | 大香网伊人 | 日日噜噜噜夜夜爽爽狠狠视频, | 色橹橹欧美在线观看视频高清 | 污免费网站 | 久久精品一级 | 成人中文字幕在线观看 | 成人久久久久久久久 | 久视频在线观看 | 国产精品毛片无码 | 午夜精品久久久久久久久久久久 | 色偷偷888欧美精品久久久 | 91资源在线| 四虎影院在线播放 | 日韩精品影院 | 日一区二区 | 精品日韩 | 日韩久久中文字幕 | 国产精品毛片一区二区三区 | 精品1区| 久久久一区二区三区 | www.天天干.com| 国产亚洲欧美日韩精品一区二区三区 | 国产精品视频一二三区 | 三级黄色片在线播放 | 亚洲一区二区三区在线视频 | 久久中文字幕一区 | 欧美日韩精品综合 | 综合久久国产 | 最新国产精品精品视频 | 国产做a爱片久久毛片 |