SQLserver中的declare變量用法
SQL中的declare用法
平時(shí)寫SQL查詢、存儲(chǔ)過程都是憑著感覺來(lái),沒有探究過SQL的具體語(yǔ)法,一直都是按c#那一套往SQL上模仿,前幾天項(xiàng)目中碰到一個(gè)問題引起了我對(duì)declare定義變量的作用域的興趣。
大家都知道c#中的局部變量,在if中如果我們定義一個(gè)變量的話他的作用到if結(jié)束為止,if外是不識(shí)別這個(gè)變量的,else里都不能使用,簡(jiǎn)單的寫一下。
if(true) { Int32i=1; Console.WriteLine(i); }
這個(gè)i的作用域就是if里面,如果我們?cè)趇f外面用這個(gè)變量
if(true) { Int32i=1; Console.WriteLine(i); } Console.WriteLine(i);
那第二條輸出語(yǔ)句會(huì)報(bào)錯(cuò)
The name 'i' does not exist in the current context
說(shuō)明已經(jīng)出了i的作用域了。
那么我們要是在sql寫這么一段代碼會(huì)是什么情況呢?首先寫在if內(nèi)
IF1=1 BEGIN DECLARE@testVARCHAR SET@test='1' PRINT'inif:'+@test END
運(yùn)行看結(jié)果輸出in if:1這是可以預(yù)想的結(jié)果。那我們?cè)趇f外面使用變量@test試試。
IF1=1 BEGIN DECLARE@testVARCHAR SET@test='1' PRINT'inif:'+@test END PRINT'outif:'+@test
這樣會(huì)是什么結(jié)果呢,不知道大家怎么想的,以我的大腦順勢(shì)就想到這應(yīng)該報(bào)錯(cuò)啊,出了變量的作用域了。實(shí)際結(jié)果不僅沒報(bào)錯(cuò)而且@test的值還在。
in if:1
out if:1
看見這個(gè)結(jié)果當(dāng)時(shí)我很郁悶,SQL太出人意料了。
在SQL SERVER 2005的幫助文檔里關(guān)于declare的幫助里發(fā)現(xiàn)這么一句話,備注的第三行“局部變量的作用域是其被聲明時(shí)所在批處理”
Msdn的地址:http://msdn.microsoft.com/zh-cn/library/ms188927.aspx
這行字在這么一大篇中還真挺不引人矚目。
現(xiàn)在我們知道原來(lái)declare變量的作用域是所在的批處理,if阻斷不了它的作用域,那上面我們的代碼if內(nèi)外的代碼都在一個(gè)批處理中,所以@test都是可用的且if里面設(shè)置的值還在。
下面我改造一下代碼,SQL中是以GO語(yǔ)句來(lái)區(qū)分批處理的
IF1=1 BEGIN DECLARE@testVARCHAR SET@test='1' PRINT'inif:'+@test END GO PRINT'outif:'+@test
這下對(duì)了,檢查語(yǔ)法后SQL報(bào)錯(cuò)“必須聲明標(biāo)量變量"@test"”
注:GO就是用于一個(gè)sql語(yǔ)句的結(jié)束 比如說(shuō)一個(gè)批處理語(yǔ)句是這樣的 select *from ,b select *from a 在后一個(gè)select后面加上一個(gè)GO這樣可以一次執(zhí)行兩條sql 語(yǔ)句
到此這篇關(guān)于SQL server中的declare變量用法的文章就介紹到這了,更多相關(guān)SQL server中的declare變量?jī)?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sql2005 附加數(shù)據(jù)庫(kù)出錯(cuò)(錯(cuò)誤號(hào):5123)解決方法
無(wú)法為此請(qǐng)求檢索數(shù)據(jù)。(Microsoft.SqlServer.SmoEnum)其他信息執(zhí)行Transact-Sql語(yǔ)句或批處理時(shí)發(fā)生了異常,Microsoft.SqlServer.ConnectionInfo)嘗試打開或創(chuàng)建物理文件d:\Data\***.mdf時(shí),Create file遇到操作系統(tǒng)錯(cuò)誤5(拒絕訪問。2012-07-07Sql server 備份還原后出現(xiàn) 受限制用戶 問題
怎么解決Sql Server 2005數(shù)據(jù)庫(kù)備份還原后出現(xiàn)“受限制用戶”,這是大家在數(shù)據(jù)庫(kù)備份還原后經(jīng)常遇到的問題,我們今天就來(lái)探討下.2020-03-03SQL Server 2005 更改安裝路徑目錄的方法小結(jié)
這篇文章主要介紹了SQL Server 2005 更改安裝路徑目錄的方法,需要的朋友可以參考下2014-11-11簡(jiǎn)單實(shí)用SQL腳本Part SQLServer 2005 鏈接服務(wù)器
SQL Server 2005版本的SSMS中已經(jīng)有了 服務(wù)器對(duì)象->鏈接服務(wù)器 的功能點(diǎn),用戶首先創(chuàng)建一個(gè)遠(yuǎn)程DB的鏈接對(duì)象,之后就可以像本地表一樣執(zhí)行表的DML了。2010-09-09sql2008 附加數(shù)據(jù)庫(kù)時(shí)出現(xiàn)錯(cuò)誤5123提示的解決方法
今天重裝了一下家里電腦的數(shù)據(jù)庫(kù),在附加己有數(shù)據(jù)庫(kù)時(shí),出現(xiàn)5123錯(cuò)誤2011-11-11SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法
SQL Server 2005 引入幾個(gè)新的排序(排名)函數(shù),如ROW_NUMBER、RANK、DENSE_RANK等。這些新函數(shù)使您可以有效地分析數(shù)據(jù)以及向查詢的結(jié)果行提供排序值。2010-07-07PowerDesigner中如何導(dǎo)入SQL Server數(shù)據(jù)庫(kù)
這篇文章向我們介紹了如何導(dǎo)入SQL Server數(shù)據(jù)庫(kù)到PowerDesigner中的詳細(xì)步驟說(shuō)明,并附帶圖片介紹,需要了解的朋友可以參考下2015-07-07