SQL Server 抛出自定义相当,由C#程序俘获之并举办相应的拍卖

 

如今一直在找可以自定义非常,并用C#先后捕获并展开对应的处理,试了累累措施都不曾成功。前几日算是找到了科学的办法。所以转载并分享给我们。

摘自:http://www.cnblogs.com/scottckt/archive/2007/12/07/986847.html

在 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
级另外失实,被认为是沉重的;际遇致命的级别错误,客户端的连天将在吸纳消息后终止。C#
中的 catch 块中得以俘获 错误级别 11 到 19 级其余分外。

0 到 10 级其它荒唐历来不进catch 块;而 20 到 25
级其余不胜,被认为是沉重的,会被断开数据库连接。所以 C# cath
块可以承受到这种特别,但特此外始末不是的确的不行内容,可能是相仿这样的情节:“在从服务器收到结果时发生传输级错误”。

        public void GetSqlError()

        {

            try

            {

                string connString = “Data
Source=CCM02//SQLEXPRESS;Initial Catalog=Northwind;User
ID=sa;Password=sh2_123”;

                string sql = “select * from Products”;

C#,                string raisError = “RAISERROR(‘Rais Error1’, 16, 1) WITH
NOWAIT”;

                sql = sql + “;” + raisError;

                SqlConnection con = new SqlConnection(connString);

                SqlCommand cmd = new SqlCommand(sql, con);

                con.Open();

                cmd.ExecuteNonQuery();

                con.Close();

            }

            catch (Exception ex)

            {

                rtbValue.Text = ex.Message.ToString();

            }

        }

結果:

    rtbValue.Text的值為:“Rais Error1”

相关文章