sql server try...catch使用

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:

Transact-SQL 代码中的错误可使用 TRY…CATCH 构造处理,此功能类似于C#语言的异常处理功能。TRY…CATCH 构造包括两部分:一个 TRY 块和一个 CATCH 块

1.TRY...CATCH 块不处理导致数据库引擎关闭连接的严重性为 20 或更高的错误。但是,只要连接不关闭,TRY...CATCH 就会处理严重性为 20 或更高的错误。

2.严重性为 10 或更低的错误被视为警告或信息性消息,TRY...CATCH 块不处理此类错误。

1--ids 主键 2createtable test1( ids intnotnull,
3constraint pk_test1 primarykey(ids)
4)
5go
6select*from test1
7begin try
89BEGINTRAN10insertinto test1 (ids)
11select11213insertinto test1 (ids)
14select21516insertinto test1 (ids)
17select1--违反了主键约束 1819COMMITTRAN20PRINT'Transaction committed'
21end try
22begin catch
23ROLLBACK24PRINT'Transaction rolled back'2526SELECT27 ERROR_NUMBER() AS ErrorNumber,
28 ERROR_SEVERITY() AS ErrorSeverity,
29 ERROR_STATE() AS ErrorState,
30 ERROR_PROCEDURE() AS ErrorProcedure,
31 ERROR_LINE() AS ErrorLine,
32 ERROR_MESSAGE() AS ErrorMessage;
33end catch
34
35select*from test1
36

TRY...CATCH 使用下列错误函数来捕获错误信息:

ERROR_NUMBER() 返回错误号。

ERROR_MESSAGE() 返回错误消息的完整文本。此文本包括为任何可替换参数(如长度、对象名或时间)提供的值。

ERROR_SEVERITY() 返回错误严重性。

ERROR_STATE() 返回错误状态号。

ERROR_LINE() 返回导致错误的例程中的行号。

ERROR_PROCEDURE() 返回出现错误的存储过程或触发器的名称。

1BEGIN TRY
2SELECT1/0;
3END TRY
4BEGIN CATCH
5SELECT6 ERROR_NUMBER() AS ErrorNumber,
7 ERROR_SEVERITY() AS ErrorSeverity,
8 ERROR_STATE() AS ErrorState,
9 ERROR_PROCEDURE() AS ErrorProcedure,
10 ERROR_LINE() AS ErrorLine,
11 ERROR_MESSAGE() AS ErrorMessage;
12END CATCH;
13


对于与TRY...CATCH 构造在同一执行级别发生的错误,TRY...CATCH 将不处理以下两类错误:

1.编译错误,例如阻止批处理执行的语法错误。

2.语句级重新编译过程中出现的错误,例如由于名称解析延迟而造成在编译后出现对象名解析错误。

1--由SELECT 语句生成的对象名解析错误是不被TRY…CATCH 构造捕捉 2BEGIN TRY
3-- Table does not exist 4SELECT*FROM Table1;
5END TRY
6BEGIN CATCH
7SELECT8 ERROR_NUMBER() AS ErrorNumber,
9 ERROR_SEVERITY() AS ErrorSeverity,
10 ERROR_STATE() AS ErrorState,
11 ERROR_PROCEDURE() AS ErrorProcedure,
12 ERROR_LINE() AS ErrorLine,
13 ERROR_MESSAGE() AS ErrorMessage;
14END CATCH
15

如果某个错误在 TRY 块内的编写或语句级别重新编写过程中并在较低的执行级别(例如,执行 sp_executesql 或用户定义存储过程时)发生,则该错误会在低于 TRY…CATCH 构造的级别上发生,并由相关联的 CATCH 块处理。
分类:  SQL
本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2012/10/08/2715216.html ,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
29天前
|
SQL 安全 算法
【SQL server】玩转SQL server数据库:第四章 数据库安全性
【SQL server】玩转SQL server数据库:第四章 数据库安全性
69 12
|
29天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
65 10
|
29天前
|
SQL 存储 算法
【SQL server】玩转SQL server数据库:第一章 绪论
【SQL server】玩转SQL server数据库:第一章 绪论
43 5
|
2月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
2月前
|
SQL 数据库
sql server中创建数据库和表的语法
sql server中创建数据库和表的语法
19 1
|
29天前
|
SQL 数据库 数据库管理
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(一)模式、表、索引与视图
60 11
|
2月前
|
SQL 安全 数据库
SQLServer 实现数据库表复制到另一个数据库_kaic
SQLServer 实现数据库表复制到另一个数据库_kaic
|
29天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
103 6
|
2天前
|
SQL 存储 数据库连接
C#SQL Server数据库基本操作(增、删、改、查)
C#SQL Server数据库基本操作(增、删、改、查)
5 0