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”;

                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”

相关文章