3rd highest salary in sql server

How to Handle Error or Exception in SQL? When you use @@Error and TRY-CATCH?

Today's, I am going to share the code sample for exception handling in SQL Server; The SQL Server exception handling is very similar to the Microsoft C# and C++ etc.

Error Handling Mechanism:-
The two types of error handling in SQL Server that is
1.      @@ERROR
2.      TRY CATCH Block

When we should use @@ERROR?
1.      While executing any stored procedures
2.      In the SQL statements like Select, Insert, Delete and Update etc.
3.      In the Open, Fetch Cursor.

When we should use Try Catch Block?

The Try Catch Block is generally used where want to catch errors for multiple SQL statements.

In the SQL Server, The TRY CATCH are catches all errors and store in the @ERRORS variable and raise the errors using the RAISERROR().

Following functions are used in CATCH block,

ERROR_NUMBER(): Will return error number.
ERROR_SEVERITY():Will return severity level.
ERROR_STATE():Will return state number.
ERROR_LINE():Will return error line number.
ERROR_PROCEDURE():Will return stored procedure name that occurred the error.
ERROR_MESSAGE():Will return full message text of the error.

Syntax:-

BEGIN TRY
 ---YOUR CODE LOGIC
END TRY
BEGIN CATCH
 ---YOUR  ERRORS HANDLER
END CATCH

The example as,

-- ============================================================
-- ABOUT :     TRY CATCH IN SQL SERVER STORED PROCEDURE
-- CREATE DATE: 22/04/2015
-- DESCRIPTION:           RETURNS [LISTEVENT]
-- PARAMETERS:  FROMDATE, TODATE
-- =============================================================
CREATE PROCEDURE  [SPX].[LISTEVENT]
(
 @FROMDATE DATETIME,
 @TODATE DATETIME
)
AS BEGIN
 BEGIN TRY
   SELECT EVENTDESC,
          EVENTNAME,
          STARTDATE,
          ENDDATE
       FROM SPX.SPORTPIXPROMOEVENTS
       WHERE STARTDATE=@FROMDATE AND ENDDATE=@TODATE
    END TRY
   
    BEGIN CATCH       
            DECLARE @ERRORS VARCHAR(8000)
            SET @ERRORS= CONVERT(VARCHAR,ERROR_NUMBER()) + '*****' +
            CONVERT(VARCHAR(4000),ERROR_MESSAGE()) + '*****' +
            ISNULL(CONVERT(VARCHAR,ERROR_PROCEDURE()),'GETPROMOTIONLIST') + '*****' +
            CONVERT(VARCHAR,ERROR_LINE()) + '*****' +
            CONVERT(VARCHAR,ERROR_SEVERITY()) + '*****' +
            CONVERT(VARCHAR,ERROR_STATE())

            RAISERROR (@ERRORS, -- MESSAGE TEXT.
                    16, -- SEVERITY.
                    1 -- STATE.
            );
    END CATCH
 END

I hope you are enjoying with this post! Please share with you friends!! Thank you!!!

ANIL SINGH

Anil Singh is an author, tech blogger, and software programmer. Book writing, tech blogging is something do extra and Anil love doing it. For more detail, kindly refer to this link..

My Tech Blog - https://www.code-sample.com/
My Books - Book 1 and Book 2

How to Handle Error or Exception in SQL? When you use @@Error and TRY-CATCH? How to Handle Error or Exception in SQL? When you use @@Error and TRY-CATCH? Reviewed by Anil Singh on 11:33 PM Rating: (5)
www.code-sample.com/. Powered by Blogger.
^