SET @error_message = ERROR_MESSAGE()
SET @error_serverity =ERROR_SEVERITY()
SET @error_state = ERROR_STATE()
RAISERROR(@error_message, @error_serverity,@error_state)
将会得到这样的结果:
RAISERROR(@error_message,@error_serverity,@error_state) WITH SETERROR七、 InfoMessage
上面的所以内容都围绕一个Exception handling的主题,在文章最后一部分我们想想一个和非Exception handling但是又和上面的内容很相关的主题:在Database通过Print语句输出的Message如何向Application传递。
在上面的例子中,有一个P_CLEAR_DATA的stored procedure,用于数据的清理。在操作结束后,有一个Print语句(PRINT ('All data have been deleted!'))
CREATE Procedure P_CLEAR_DATA
AS
DELETE FROM dbo.T_USERS_IN_ROLES
DELETE FROM dbo.T_USERS
DELETE FROM dbo.T_ROLES
PRINT ('All data have been deleted!')
GO
我们的现在的目标是在Application中,如何得到这段Message。要做到这点很简单,只需要用到SqlConnection的InfoMessage事件,当通过DbCommand执行上面一段Sql的时候,Print语句的执行将出发该事件。我们现在要做的就是注册这个事件,比如下面我们在ExecuteCommand()种添加了下面一段代码:
SqlConnection sqlConnection = connection as SqlConnection;
if (sqlConnection != null)
{
sqlConnection.InfoMessage += delegate(object sender, SqlInfoMessageEventArgs e)
{
Console.WriteLine(e.Message);
};
}
当我们调用Utility.Clear()的时候,就会输出"All data have been deleted!"
[原创]谈谈基于SQL Server的Exception Handling - PART I
[原创]谈谈基于SQL Server 的Exception Handling - PART II
[原创]谈谈基于SQL Server 的Exception Handling - PART III