欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2013年06月05日 17:25:24   作者:  
本篇文章是對(duì)SQL中SET與SELECT賦值的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
最近的項(xiàng)目寫(xiě)的SQL比較多,經(jīng)常會(huì)用到對(duì)變量賦值,而我使用SET和SELECT都會(huì)達(dá)到效果。
那就有些迷惑,這兩者有什么區(qū)別呢?什么時(shí)候哪該哪個(gè)呢?
經(jīng)過(guò)網(wǎng)上的查詢,及個(gè)人練習(xí),總結(jié)兩者有以下幾點(diǎn)主要區(qū)別:
假定有設(shè)定變量:
復(fù)制代碼 代碼如下:

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

1、SELECT可以在一條語(yǔ)句里對(duì)多個(gè)變量同時(shí)賦值,而SET只能一次對(duì)一個(gè)變量賦值,如下:
復(fù)制代碼 代碼如下:

SELECT @VAR1='Y',@VAR2='N'
-- 而SET要達(dá)到同樣的效果,需要:
SET @VAR1='Y'
SET @VAR2='N'
/*
   說(shuō)到這個(gè),SQL內(nèi)置的變量:@@ERROR 和 @@ROWCOUNT必須要在一句SQL語(yǔ)句中捕獲。如果用set分兩句來(lái)獲取它們,將獲取不完整,這時(shí)就應(yīng)該用select來(lái)獲取值。
*/

2、表達(dá)式返回多個(gè)值時(shí),用SET將會(huì)出錯(cuò),而SELECT將取最后一個(gè)值,如下:
復(fù)制代碼 代碼如下:

----以下假定Permission表有多個(gè)IsRight記錄
SELECT @VAR1 = IsRight FROM Permission   --將取最后一個(gè)值

SET @VAR1 = IsRight FROM Permission   --將報(bào)錯(cuò)

3、表達(dá)式無(wú)返回值時(shí),用SET將置變量值為NULL,用SELECT交保持變量值,如下:
復(fù)制代碼 代碼如下:

----以下假定Permission記錄為空
SET @VAR1 = '初始值'

 
SELECT @VAR1 = IsRight FROM Permission   --此時(shí)@VAR1為'初始值'

SET  @VAR1 = (SELECT IsRight FROM Permission)   --此時(shí)@VAR1為NULL

4、使用標(biāo)量子查詢時(shí),如果無(wú)返回值,SET和SELECT一樣,都將置為NULL,如下:
復(fù)制代碼 代碼如下:

----以下假定Permission記錄為空
SET @VAR1 = '初始值'

SELECT @VAR1 =(SELECT IsRight FROM Permission )   --此時(shí)@VAR1為NULL

SET  @VAR1 = ( SELECT IsRight FROM Permission)   --此時(shí)@VAR1為NULL

相關(guān)文章

最新評(píng)論