我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SQL Server中如何实现错误处理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SQL Server中如何实现错误处理

今天小编给大家分享一下SQL Server中如何实现错误处理的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

一、SQLServer数据库引擎错误

1、查询系统错误信息

SQLServer在每个数据库的系统视图sys.messages中存储系统自定义(Message_id <= 50000)和用户自定义(Message_id>50000)错误消息。

2、系统错误信息的严重性级别

得到的系统错误消息分为不同程度的严重性级别。严重性级别是通过数字来表示的,数字越小表示严重级别越低。反之则严重性越高。严重性较高的错误指示需要尽快解决问题。

二、用try...catch发现错误

try...catch结构       

begin try        要执行的T-SQL代码,一旦错误将传递给catch块进行处理      end try      begin catch        检索和处理错误信息的代码      end catch      正常执行的T-SQL语句
  • try:其中,try块是包含在begin try和end try之间的T-SQL代码段,在该代码段中一旦发生错误将传递给catch块,如果没有错误将直接执行catch块后面的代码。

  • catch:catch块是包含在begin catch和end catch之间的T-SQL代码段,在该代码段中检索和处理try块中的错误信息。

三、捕获错误的系统函数

  • error_number()
    返回错误的ID号,对应sys.messages系统视图中的message_id字段。

  • error_line()
    返回T-SQL代码中错误出现的语句行数。

  • error_message()
    返回将返回给应用程序的消息文本。该文本包括为所有可替换参数提供的值,如长度、对象名或时间。对应sys.messages系统视图中的text字段。

  • error_procedure()
    返回出现错误的存储过程或触发器名称。如果在存储过程或触发器中未出现错误,该函数返回NULL。

  • error_severity()
    返回错误的严重性级别。对应sys.messages系统视图中的severity字段。

  • error_state()
    返回状态

 示例:

begin try    select 1/0end trybegin catch    select         error_number() as 'number',        error_line() as 'line',        error_message() as 'message',        error_severity() as 'severity',        error_state()    as 'state'end catch

输出结果如图所示:

SQL Server中如何实现错误处理

四、用@@ERROR捕获上一条语句的错误

T-SQL还提供了一个简单的系统函数@@ERROR来捕获上一条语句的错误。如果上一条语句执行成功。@@ERROR系统函数将返回0;如果上一条语句生成错误,@@ERROR将返回错误号。

每条语句完成时@@ERROR都会更改。

例如:

select 1/0select * from sys.messages where message_id = @@error and language_id = 2052

 结果如图:

SQL Server中如何实现错误处理

五、用RAISERROR反馈错误

功能:

将生成的SQLServer引擎错误或警告信息(从sys.messages系统视图获得)反馈到应用程序中。sys.messages系统视图中由SQLServer自身定义的信息,其message_id列的值小于等于5000。

返回用户使用存储过程sp_addmessage创建的自定义消息(存储在系统视图sys.messages中,其message_id大于50000)。

与print语句的区别:

print语句是T-SQL提供的用于反馈信息的语句,print语句只能反馈字符串或字符串表达式的值。

raiserror语句除了print语句的功能外,还支持类似C语言仲printf函数的字符串替换功能。这样可以先在字符串中定义要替换的数据的类型和位置,在输出时自动将字符串内容进行替换。

语法: 

raiserror({ msg_id | msg_str | @local_variable })        { ,severity,state }         [ ,argument [ ,...n ] ] )         [ with option [,...n] ]

参数说明:

  • msg_id:存储在sys.messages系统视图中的错误消息号(message_id)。如果是用户使用as_addmessage系统存储过程自定义的错误消息,其错误号应当大于50000.如果未指定msg_id,则返回一个错误号为50000的错误消息。

  • msg_str:用户自定义消息,msg_str是一个字符串,具有可选的嵌入转换规格。每个转换规格都会定义参数列表中的值。如何格式化并将其置于msg_str中转换规格位置上的字段中,转换规格的格式如下:%[[flag][width][.precision][{h|1}]]type。

  • @local_variable:包含按照msg_str的方式格式化的字符串的任何有效字符串数据类型的变量。@local_variable的数据类型必须为char或varchar,或者必须能够隐式转换为这些数据类型。

  • severity:用户定义的与该消息关联的严重级别。当使用msg_id引发使用sp_addmessage创建的用户定义消息时,paiserror上指定的严重性将覆盖sp_addmessage中指定的严重性。

  • state:状态号,1至少127之间的任意整数。如果在多个位置引发相同的用户自定义错误,则针对每个位置使用唯一的状态好有助于找到引发错误的代码段。

  • argument:用于代替msg_str或对应于msg_id的消息中的定义的变量的参数。可以有0个或多个替代参数,但是替代参数的总数不能超过20个。

  • option:错误的自定义选项。LOG:在SQLServer数据库引擎实例的错误日志和应用程序日志中记录错误;NOWAIT:将消息立即发送给客户端;SETERROR:将@@ERROR值和ERROR_NUMBER值设置为msg_id或50000,不用考虑严重级别。

以上就是“SQL Server中如何实现错误处理”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SQL Server中如何实现错误处理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL Server中如何实现错误处理

今天小编给大家分享一下SQL Server中如何实现错误处理的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、SQLServ
2023-06-30

SQL Server附加数据库时出现错误的处理方法

通过附加功能添加现成的数据库是非常方便的,然而有时会出现附加数据库失败,下面这篇文章主要给大家介绍了关于SQL Server附加数据库时出现错误的处理方法,需要的朋友可以参考下
2022-12-15

SQL Server附加数据库时出现错误的处理方法

目录前言一、如何附加数据库?二、无法升级数据库,出现(539类似版本号不匹配)错误解决办法1.常见的无法附加数据库时,出现的错误2.无法升级数据库的解决办法总结前言SQL Server 是数据库软件中比较常见且实用的软件,它的集成度很高,
2022-12-15

golang函数中的错误处理是如何实现的?

go 语言中函数错误处理通过返回一个 error 接口类型的错误来实现。1. 内建的 error 接口类型的 error() 方法返回错误的描述字符串。2. 通过 if err != nil 比较错误是否为空来处理错误。3. 错误处理适用于
golang函数中的错误处理是如何实现的?
2024-05-23

PHP中如何处理ORM错误?

PHP中如何处理ORM错误?在开发中,当使用ORM(对象关系映射)工具来管理数据库时,可能会遇到一些错误。处理这些错误是非常重要的,以确保应用程序能够正常工作并提供正确的错误反馈给用户。本文将介绍如何在PHP中处理ORM错误,并提供具体的代
PHP中如何处理ORM错误?
2023-12-17

PHP中如何处理图像处理错误?

PHP中如何处理图像处理错误?图像处理在网页开发中非常常见,而处理图像时经常会遇到一些错误。这些错误包括文件不存在、文件不是图像文件、文件过大等等。在图像处理过程中,我们需要能够准确地捕获这些错误,并对其进行适当的处理。本文将介绍一些在PH
PHP中如何处理图像处理错误?
2023-12-09

如何在SQL Server中实现和管理数据分发

在SQL Server中,您可以使用以下方法来实现和管理数据分发:使用SQL Server Replication:SQL Server提供了一种内置的数据分发机制,即复制。通过设置发布者、分发者和订阅者,可以将数据从一个数据库实例复制到另
如何在SQL Server中实现和管理数据分发
2024-06-04

vbScript中如何进行错误处理

这篇文章将为大家详细讲解有关vbScript中如何进行错误处理,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。vbscript中,错误处理使用on error resume next来完成,如果在你的代码里
2023-06-08

PHP中如何处理并发错误?

PHP中如何处理并发错误?在开发Web应用程序时,我们经常会遇到并发错误的问题。并发错误是指多个用户同时访问同一段代码时可能出现的问题,如数据库死锁、资源竞争等。为了保证代码的正确性和性能,我们需要采取一些措施来处理并发错误。以下是一些处理
PHP中如何处理并发错误?
2023-12-18

PHP中如何处理日志错误?

PHP是一种广泛应用于Web开发的脚本语言,其应用场景很多,例如网站、CMS、后台管理系统等。随着业务的复杂度提高,出现错误的可能性也会增大,这时候就需要系统的错误日志记录,方便开发人员及时排查问题。以下是针对PHP中如何处理日志错误的一些
PHP中如何处理日志错误?
2023-12-18

C++ 函数中如何处理错误?

c++++ 中处理错误的最佳实践包括使用异常处理异常情况,以及使用错误代码表示非致命错误。异常抛出自定义错误信息,通过 try-catch 块进行捕获和处理;错误代码用于轻微错误,在检查后通过 if-else 语句进行处理。通过抛出一个异常
C++ 函数中如何处理错误?
2024-04-23

如何处理php中DateTime的错误

这篇文章主要讲解了“如何处理php中DateTime的错误”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何处理php中DateTime的错误”吧!说明1、DateTime对象可以过程化地写
2023-06-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录