基於SQL中SET與SELECT賦值的差別詳解。本站提示廣大學習愛好者:(基於SQL中SET與SELECT賦值的差別詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是基於SQL中SET與SELECT賦值的差別詳解正文
比來的項目寫的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