日韩欧美人妻无码精品白浆,www.大香蕉久久网,狠狠的日狠狠的操,日本好好热在线观看

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

SQL優(yōu)化:合理使用變量

admin
2025年6月21日 23:58 本文熱度 85

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



1
什么是變量


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

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

DECLARE @I VARCHAR(20)

--對變量@I賦值為

SET @I='SQL數(shù)據(jù)庫開發(fā)'

--輸出@I的值

SELECT @I

結(jié)果:SQL數(shù)據(jù)庫開發(fā)

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

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

  • 定義好變量后就可以將其帶入到查詢語句中了,每次只需要修改賦值部分,查詢語句就會根據(jù)賦值內(nèi)容查詢出相應(yīng)的結(jié)果



2
為什么要使用變量


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

SELECT * FROM T1 WHERE ORDER_ID='112';

SELECT * FROM T1 WHERE ORDER_ID='113';

如果單獨執(zhí)行這兩條查詢語句,查詢優(yōu)化器認(rèn)為是不同的SQL語句,需要解析兩次。

我們使用變量對其進(jìn)行修改

DECLARE @ORDER_ID VARCHAR(20)

SET @ORDER_ID='112'

SELECT * FROM T1 WHERE ORDER_ID=@ORDER_ID;

執(zhí)行完之后,只需要修改@ORDER_ID的值為'113’,就可以重復(fù)使用上面的執(zhí)行計劃了。

由于上面的語句比較簡單,可能看不出效果,但是如果遇到比較復(fù)雜的查詢語句,變量查詢往往能起到很好的效果。



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


  • 常見的在線查詢一遍都可以使用到變量,將變量作為參數(shù)傳遞給數(shù)據(jù)庫,可以實現(xiàn)一次查詢,重復(fù)使用執(zhí)行計劃。

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


4
變量窺測

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

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

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

DECLARE @NATION VARCHAR(50)

SET @NATION='漢族'

SELECT * FROM People WHERE AGE=30 AND NATION=@NATION;

當(dāng)?shù)诙€值傳入的是“畬族”,正常情況下“畬族”在表中占的比例可能只有萬分之一,應(yīng)該采用索引查找。

DECLARE @NATION VARCHAR(50)

SET @NATION='畬族'

SELECT * FROM People WHERE AGE=30 AND NATION=@NATION;

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

今天的課就講到這里,如果對變量還有什么不明白的,可以在底下留言,我會一一回復(fù)的。

——End——


閱讀原文:原文鏈接


該文章在 2025/6/23 12:57:24 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務(wù)費用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務(wù)都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

日韩精品久久色AV。com| 亚洲午夜福利200集| 裸体美女内射高潮网站| 国产丝袜射精伦理网址| 麻豆二区免费看| 人妻熟女一区二区在线AⅤ| 国产亚洲精aa| 中文版av一区二区三区| 美女骚货在线视频| 亚洲一区欧美二区国产一区| 亚洲欧美熟妇TS二区| 麻豆99同人| 国产粉嫩久久久久久久| 亚洲精品国产美女在级| www.91蜜臀在线| 日本国产精品中文字幕| 亚洲色图欧洲乱伦综合| 久久影院爽| 一区二区精品久久无码| 免费一区小视频| 日本欧美久久黄页| 狠狠肏屄免费视频| 久久久久强奸| 大香蕉8| 水蜜桃加勒比系列| 国产欧美大屁股在线| av蜜臀中文| 春色午夜影院| 人妻色丁香| 夜夜av资源| 久久影院在线一区| 风间由美无码一区二区三区在线观看| 经典三级一去| 久久久久久机同| 国产原创Av无码| 内射大波人妻少妇| 被大鸡吧猛插视频| 国产无码电影久久久久久久久久久| 欧洲一级成人高清视频在线| 国产av福利成人| 亚洲AV青青草|