基于SQL中SET與SELECT賦值的區別詳解_MySQL
來源:懂視網
責編:小采
時間:2020-11-09 18:56:06
基于SQL中SET與SELECT賦值的區別詳解_MySQL
基于SQL中SET與SELECT賦值的區別詳解_MySQL:bitsCN.com 最近的項目寫的SQL比較多,經常會用到對變量賦值,而我使用SET和SELECT都會達到效果。那就有些迷惑,這兩者有什么區別呢?什么時候哪該哪個呢?經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別:假定有設定變量:DECLARE @VA
導讀基于SQL中SET與SELECT賦值的區別詳解_MySQL:bitsCN.com 最近的項目寫的SQL比較多,經常會用到對變量賦值,而我使用SET和SELECT都會達到效果。那就有些迷惑,這兩者有什么區別呢?什么時候哪該哪個呢?經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別:假定有設定變量:DECLARE @VA

bitsCN.com
最近的項目寫的SQL比較多,經常會用到對變量賦值,而我使用SET和SELECT都會達到效果。
那就有些迷惑,這兩者有什么區別呢?什么時候哪該哪個呢?
經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別:
假定有設定變量:
DECLARE @VAR1 VARCHAR(1)
DECLARE @VAR2 VARCHAR(2)
1、SELECT可以在一條語句里對多個變量同時賦值,而SET只能一次對一個變量賦值,如下:
SELECT @VAR1='Y',@VAR2='N'
-- 而SET要達到同樣的效果,需要:
SET @VAR1='Y'
SET @VAR2='N'
/*
說到這個,SQL內置的變量:@@ERROR 和 @@ROWCOUNT必須要在一句SQL語句中捕獲。如果用set分兩句來獲取它們,將獲取不完整,這時就應該用select來獲取值。
*/
2、表達式返回多個值時,用SET將會出錯,而SELECT將取最后一個值,如下:
----以下假定Permission表有多個IsRight記錄
SELECT @VAR1 = IsRight FROM Permission --將取最后一個值
SET @VAR1 = IsRight FROM Permission --將報錯
3、表達式無返回值時,用SET將置變量值為NULL,用SELECT交保持變量值,如下:
----以下假定Permission記錄為空
SET @VAR1 = '初始值'
SELECT @VAR1 = IsRight FROM Permission --此時@VAR1為'初始值'
SET @VAR1 = (SELECT IsRight FROM Permission) --此時@VAR1為NULL
4、使用標量子查詢時,如果無返回值,SET和SELECT一樣,都將置為NULL,如下:
----以下假定Permission記錄為空
SET @VAR1 = '初始值'
SELECT @VAR1 =(SELECT IsRight FROM Permission ) --此時@VAR1為NULL
SET @VAR1 = ( SELECT IsRight FROM Permission) --此時@VAR1為NULL
bitsCN.com
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
基于SQL中SET與SELECT賦值的區別詳解_MySQL
基于SQL中SET與SELECT賦值的區別詳解_MySQL:bitsCN.com 最近的項目寫的SQL比較多,經常會用到對變量賦值,而我使用SET和SELECT都會達到效果。那就有些迷惑,這兩者有什么區別呢?什么時候哪該哪個呢?經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別:假定有設定變量:DECLARE @VA