@@ERROR:當前一個語句遇到錯誤,則返回錯誤號,否則返回0。需要注意的是@ERROR在每一條語句執行后會被立刻重置,因此應該在要驗證的語句執行后檢查數值或者是將它保存到局部變量中以備將來使用。
DECLARE @num INT,@temp INT DECLARE @err INT SELECT @temp=0; SET @err=0 SET @num =2/@temp; --執行后@@ERROR為8134 PRINT @@ERROR --執行后@@ERROR為0 IF @@ERROR = 0 BEGIN PRINT @@ERROR END
分析:上面的SQL語句出現除0的錯誤,拋出錯誤信息,所以在執行除0語句后的@@Error數值是8134,但是在執行第一個Print @Error語句輸出錯誤信息之后,注意,此時@@Error的數據立即變成了0!,這一點非常重要,因為@@Error在每一條語句執行后立刻被重置!同樣的道理,執行IF @@ERROR = 0語句后@@ERROR的數值仍然是0,因為這句話也沒有發生錯誤!
