ठीक है, मैं अपनी एरर हैंडलिंग को वापस इसमें जोड़ूंगा :-)
ERROR_%() फ़ंक्शन CATCH ब्लॉक के दायरे में दिखाई देते हैं। इसका मतलब है कि आप उन्हें प्रत्येक कैच ब्लॉक में संग्रहीत खरीद या फ़ंक्शन कॉल में उपयोग कर सकते हैं
और नेस्टेड संग्रहित प्रोसेस के साथ, यह जानना उपयोगी होता है कि त्रुटि किस कारण से हुई और क्या त्रुटि दर्ज कर रहा है
...
END TRY
BEGIN CATCH
IF XACT_STATE() <> 0 AND @starttrancount = 0
ROLLBACK TRANSACTION
EXEC dbo.MyExceptionHandler @@PROCID, @errmsg OUTPUT;
RAISERROR (@errmsg, 16, 1);
END CATCH
---with this handler (cut down version of ours)
CREATE PROCEDURE dbo.MyExceptionHandler
@CallerProcID int,
@ErrorMessage varchar(2000) OUTPUT
WITH EXECUTE AS OWNER --may be needed to get around metadata visibility issues of OBJECT_NAME
AS
SET NOCOUNT, XACT_ABORT ON;
BEGIN TRY
SET @ErrorMessage = --cutdown
CASE
WHEN @errproc = @callerproc THEN --Caller = error generator
--build up stuff
ELSE --Just append stuff --Nested error stack
END;
IF @@TRANCOUNT = 0
INSERT dbo.Exception (Who, TheError, WhatBy, LoggedBy)
VALUES (ORIGINAL_LOGIN()), RTRIM(ERROR_MESSAGE()), ERROR_PROCEDURE(), OBJECT_NAME(@CallerProcID));
END TRY
BEGIN CATCH
--and do what exactly?
END CATCH
GO
वैसे भी यह मूल विचार है:प्रत्येक कैच ब्लॉक सरल है, त्रुटि हैंडलर में काम चल रहा है। उदाहरण के लिए ERROR_NUMBER()
संलग्न करें अगर आप चाहते हैं