国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

基于SQL中SET與SELECT賦值的區(qū)別詳解

2024-07-24 12:48:29
字體:
供稿:網(wǎng)友
最近的項目寫的SQL比較多,經(jīng)常會用到對變量賦值,而我使用SET和SELECT都會達到效果。
那就有些迷惑,這兩者有什么區(qū)別呢?什么時候哪該哪個呢?
經(jīng)過網(wǎng)上的查詢,及個人練習,總結(jié)兩者有以下幾點主要區(qū)別:
假定有設定變量:
復制代碼 代碼如下:

DECLARE @VAR1 VARCHAR(1)
DECLARE @VAR2 VARCHAR(2)

1、SELECT可以在一條語句里對多個變量同時賦值,而SET只能一次對一個變量賦值,如下:
復制代碼 代碼如下:

SELECT @VAR1='Y',@VAR2='N'
-- 而SET要達到同樣的效果,需要:
SET @VAR1='Y'
SET @VAR2='N'
/*
   說到這個,SQL內(nèi)置的變量:@@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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 沾益县| 石嘴山市| 银川市| 什邡市| 平塘县| 达拉特旗| 星子县| 密云县| 湘乡市| 忻州市| 尼玛县| 法库县| 北碚区| 营口市| 霍林郭勒市| 翁源县| 阜平县| 兴和县| 台北县| 兴业县| 义马市| 海林市| 河北省| 漯河市| 皮山县| 漳浦县| 久治县| 沈阳市| 林甸县| 嘉祥县| 论坛| 精河县| 阳城县| 温泉县| 泸定县| 普格县| 汉沽区| 新安县| 清远市| 英超| 正阳县|