@@ ERROR und / oder TRY - CATCH

Erfasst Try-Catch alle Fehler, die durch @@ FEHLER verursacht werden können? Lohnt es sich, im folgenden Codefragment nach @@ ERROR zu suchen? Wird RETURN 1111 jemals auftreten?

SET XACT_ABORT ON
BEGIN TRANSACTION

BEGIN TRY
    --do sql command here  <<<<<<<<<<<

    SELECT @Error=@@ERROR
    IF @Error!=0
    BEGIN
        IF XACT_STATE()!=0
        BEGIN
            ROLLBACK TRANSACTION
        END
        RETURN 1111
    END

END TRY
BEGIN CATCH

    IF XACT_STATE()!=0
    BEGIN
        ROLLBACK TRANSACTION
    END
    RETURN 2222

END CATCH

IF XACT_STATE()=1
BEGIN
    COMMIT
END

RETURN 0

Antworten auf die Frage(6)

Ihre Antwort auf die Frage