中C# catch 块中可以俘获 SQL Server 抛出的自定义异常(RAISERROR)
来源:互联网 发布:永恒python 编辑:程序博客网 时间:2024/05/29 14:22
中C# catch 块中可以俘获 SQL Server 抛出的自定义异常(RAISERROR)
在 SQL Server 的存储过程中根据业务逻辑的要求,有时需要抛出自定义异常,由C#程序俘获之并进行相应的处理。
SQL Server 抛出自定义异常和简单,像这样就可以了:RAISERROR('Rais Error1', 16, 1) WITH NOWAIT
但定用什么样的错误级别却很讲究,否则 C# 中的 catch 块可能俘获不到的。
SQL Servr 抛出自定义异常的方法一般这么写就可以:
RAISERROR('Rais Error1', 16, 1) WITH NOWAIT
其中数字 16 代表错误级别:
错误级别从 0 到 25, 其中 19 到 25 是重大错误级别。
注:小于 0 的级别被解释为 0,大于 25 的级别被解释为 25。
任何用户都可以指定 0 到 18 之间的错误级别。
19 到 25 级别的错误,只能由 sysadmin 角色的成员用 WITH LOG 选项指定。
19 到 25 级别的错误,将记录到错误日志和应用程序日志。
20 到 25 级别的错误,被认为是致命的;遇到致命的级别错误,客户端的连接将在收到消息后终止。
0 到 10 级别的错误根本不进catch 块;而 20 到 25 级别的异常,被认为是致命的,会被断开数据库连接。所以 C# cath 块可以接受到这种异常,
但异常的内容不是真正的异常内容,可能是类似这样的内容:“在从服务器接收结果时发生传输级错误”。
public static void GetSqlError()
{
try
{
string conString = "server=(local);uid=sa;pwd=sql;database=test1";
string sql = "select * from t1";
string raisError = "RAISERROR('Rais Error1', 16, 1) WITH NOWAIT";
sql = sql + ";" + raisError;
SqlConnection con = new SqlConnection(conString);
SqlCommand cmd = new SqlCommand(sql, con);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
{
try
{
string conString = "server=(local);uid=sa;pwd=sql;database=test1";
string sql = "select * from t1";
string raisError = "RAISERROR('Rais Error1', 16, 1) WITH NOWAIT";
sql = sql + ";" + raisError;
SqlConnection con = new SqlConnection(conString);
SqlCommand cmd = new SqlCommand(sql, con);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
源址:http://www.cnblogs.com/anjou/archive/2007/11/17/962846.html
- 中C# catch 块中可以俘获 SQL Server 抛出的自定义异常(RAISERROR)
- C# catch 块中可以俘获 SQL Server 抛出的自定义异常(RAISERROR)(轉)
- SQL Server 存储过程中使用raiserror抛出异常
- SQL Server自定义异常的使用raiserror
- RAISERROR 抛出的错误未进入 CATCH 块
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server 中 RAISERROR 的用法
- SQL Server中raiserror的介绍
- sql2005分区表
- telnet 登陆163使用smtp发送邮件
- Linux下递归修改文件时间戳
- 一个关于cygwin的问题
- 关于html,htm文件图标问题解决方法
- 中C# catch 块中可以俘获 SQL Server 抛出的自定义异常(RAISERROR)
- FreeNAS
- mysql5.1配置
- 软件需求简述(转)
- php report报表引擎
- php+iis6+mysql+win2003
- Java多线程初学者指南(4):线程的生命周期
- 异常捕获
- netstat命令