sqlserver如何得详细错误处理信息

sqlserver如何得详细错误处理信息

ID:9403601

大小:50.00 KB

页数:4页

时间:2018-04-30

sqlserver如何得详细错误处理信息_第1页
sqlserver如何得详细错误处理信息_第2页
sqlserver如何得详细错误处理信息_第3页
sqlserver如何得详细错误处理信息_第4页
资源描述:

《sqlserver如何得详细错误处理信息》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、SQLServer如何得详细错误处理信息>>教育资源库  在最近的一篇文章中,我讲过如何在SQLServer2000中发现问题。在SQLServer2005中处理错误,最重要的因素是ERROR变量。每个语句执行以后,你必须查询这个变量值,以保证没有使事务回滚的错误发生。这种方法有些麻烦,更重要的是,还容易出错。另外,在SQLServer2000中能够处理的错误类型仅限于某些类型的错误。终止事务或批处理的错误就无法处理,也没有详细的错误信息。  TRYCATCH  SQLServer2005提供TRYCATCH结构,它出现在许多现代迭代程序语言之中,如Java和C#中。此结构让你通过CA

2、TCH结构中的一系列新函数访问更为详细的错误信息,这些函数包括:  ERROR_NUMBER:返回错误号码,与ERROR的值相同。  ERROR_SEVERITY:返回调用CATCH块错误的严重程度。  ERROR_STATE:返回错误状态号码。  ERROR_LINE:返回错误发生的行号。  ERROR_PROCEDURE:返回促使错误发生的存储程序和触发器的名称。  ERROR_MESSAGE:返回错误的完整信息文本。  在CATCH块内,你可以在任何地方应用这些函数,它们将返回与发生的错误有关的信息。在CATCH块外,这些函数返回零值。  处理死锁错误  让我们来看一个例子,了解

3、如何应用SQLServer2005中的新错误处理功能来处理死锁情形,在SQLServer2000的数据库级别下,这种问题几乎无法处理。  计算机中存在资源竞争就会发生死锁。这种情形并非仅发生在数据库管理系统中,还发生在操作系统或其他任何出现资源争夺的系统中。当一个进程锁定特定的资源,而又需要另外的资源来完成任务时,就会发生死锁。如果另一个进程锁定了第一个进程需要的资源,而且还需要第一个进程获得的资源,就会出现僵局。两个进程都不愿释放自己的资源,意味着两个进程都不能完成自己的任务。  不过,SQLServe中本身就存在一个运算法则,在这种情形下,它会随机选择一个失败者,这个失败者释放自己

4、的资源以便另一个进程能够完成自己的任务。这就意味着那个被终止的进程必须再次尝试。在SQLServer2000及更早的版本中,解决这种情形的最佳方法是在业务层专门针对死锁编写代码,如果探测到死锁情况,就再次尝试事务。随着时间的推移,如果你注意到死锁情形发生的趋势,你就可以在存储程序中包括逻辑,设定死锁的优先权。这种方法允许你在死锁情形下选择失败者,但你无法再次尝试被终止的进程。  用SQLServer2005,你能够在数据层发现错误,这样业务层开发人员就不必担心事务再次尝试问题。如果你能够发现一个死锁错误,你就需要再次尝试语句(可能要在一段时间之后,以便释放所需的资源)。  为说明这些新

5、功能的运作情况,查看列表A。表中的代码用来记录发生的错误。我希望记录错误处理函数的所有信息,以及错误发生的日期和发生错误的数据库。  我将用列表B中的代码来记录程序中发生的所有错误。注意你不必给程序设定任何参数,此程序将访问上面描述的错误处理函数。这是因为在执行CATCH块的时候,你可以调用这个程序。即使调用了其他程序,你也可以在CATCH块的任何地方参考这些函数。  列表C专门用来查检死锁错误号,此时为1205。如果FicticiousTable1更新时发生死锁错误,语句即被重试三次。如果重试三次后还不能成功更新,就停止更新此表。  SQLServer2005错误处理的优点  与之前

6、的版本相比,SQLServer2005提供了一种更为稳健的错误处理工具。在SQLServer2000数据库层几乎无法处理的死锁问题,现在也能轻松解决。>>>>这篇文章来自..,。

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。