要捕获@@error和@@rowcount从一个单一查询,可以使用TRY-CATCH块和使用@@error和@@rowcount系统变量。
下面是一个示例代码:
BEGIN TRY
-- 此处是你的查询语句
SELECT * FROM your_table WHERE your_condition;
-- 检查查询是否成功,如果成功,@@error将为0
IF @@ERROR = 0
BEGIN
-- 获取查询影响的行数
DECLARE @rowCount INT;
SET @rowCount = @@ROWCOUNT;
-- 打印查询结果
PRINT '查询成功!影响的行数:' + CAST(@rowCount AS NVARCHAR(10));
END
ELSE
BEGIN
-- 查询出错,打印错误信息
DECLARE @errorMsg NVARCHAR(255);
SET @errorMsg = '查询出错!错误代码:' + CAST(@@ERROR AS NVARCHAR(10));
PRINT @errorMsg;
END
END TRY
BEGIN CATCH
-- 捕获并处理异常
PRINT '捕获到异常:' + ERROR_MESSAGE();
END CATCH
在这个例子中,我们使用TRY-CATCH块来捕获可能发生的异常。在TRY块中,我们执行你的查询语句。然后,我们检查@@error变量的值来确定查询是否成功。如果@@error为0,表示查询成功,我们可以使用@@rowcount获取受影响的行数。如果@@error不为0,表示查询出错,我们可以使用ERROR_MESSAGE()函数获取错误消息。
你可以根据你的需要修改代码,例如,将查询语句替换为你自己的查询,或者执行其他操作。
上一篇:不混合地录制每个通道