```sql
BEGIN TRY
-- 尝试执行一些可能会出现异常的代码
SELECT 1/0; -- 这里会产生一个除零异常
END TRY
BEGIN CATCH
-- 捕获异常并处理
SELECT
ERROR_NUMBER() AS ErrorNumber,
ERROR_MESSAGE() AS ErrorMessage;
END CATCH
```
在上面的示例中,当执行SELECT 1/0语句时会出现除零异常,并且会被TRY...CATCH块捕获。在CATCH块中,可以使用ERROR_NUMBER()和ERROR_MESSAGE()函数来获取异常的错误号和错误消息。
除了使用TRY...CATCH块外,还可以使用RAISEERROR语句来抛出自定义的错误信息。例如:
```sql
IF (1=1)
RAISEERROR('Custom error message', 16, 1);
```
在上面的示例中,如果条件1=1成立,则会抛出一个自定义的错误消息"Custom error message"。 RAISEERROR语句的第一个参数是错误消息,第二个参数是错误级别(在16和25之间),第三个参数是状态号。
总的来说,通过TRY...CATCH块和RAISEERROR语句,可以在SQLServer中有效地处理异常和错误信息。