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

最新文章

  1. 《C与指针》第七章练习
  2. Modbus通讯协议学习 - 串口调试
  3. HDU 5742 It's All In The Mind (贪心) 2016杭电多校联合第二场
  4. GPU 优化总结
  5. Nginx之负载均衡
  6. 去掉php框架CI默认url中的index.php
  7. JavaCodeTra 猴子选猴王 约瑟夫循环
  8. Solr开发参考文档(转)
  9. C# ignoring letter case for if statement(Stackoverflow)
  10. css3 animation动画事件
  11. iframe与父页面的js通信
  12. 达到工业使用质量级别的类似于QQ截屏的软件
  13. 浅谈Java接口
  14. Vue框架
  15. Css技术入门笔记01
  16. 【XSY3139】预言家 数位DP NFA
  17. PHP菜鸟如何开始学习PHP语言
  18. elasticsearch 二、elasticsearch-head安装
  19. fbs创建windows下安装qtpy应用程序!
  20. MacBook Pro 一月使用体验

热门文章

  1. 《挑战程序设计竞赛》2.4 数据结构-并查集 POJ1182 2236 1703 AOJ2170
  2. REDO 的内容:改变向量
  3. windows 系统如何安装 mysql 8.0.15 数据库?
  4. 深入理解Redis主键失效原理及实现机制(转)
  5. requests 中response如何改变编码格式
  6. Android Studio "佛祖保佑 永无bug" 注释模板设置详解(仅供娱乐)
  7. Django的模型层(1)- 单表操作(上)
  8. linux c编程:互斥锁条件变量
  9. StringBuilder String string.Concat 字符串拼接速度
  10. Java并发(6):concurrent包中的Copy-On-Write容器