Error Handling In Store Procedure
Contents |
Errors in SQL Server 2012 03 January 2013Handling Errors in SQL Server 2012The error handling of SQL Server has always error handling in stored procedure sql server 2008 been somewhat mysterious. Now at last, the THROW statement has been included error handling in stored procedure sql server in SQL Server 2012 that, combined with the TRY ... CATCH block, makes error handling far easier. Robert error handling in stored procedure sql server 2012 Sheldon explains all. 194 14 Robert Sheldon Since the release of SQL Server 2005, you've been able to handle errors in your T-SQL code by including a TRY…CATCH block that
Error Handling In Stored Procedure Oracle
controls the flow of your script should an error occur, similar to how procedural languages have traditionally handled errors. The TRY…CATCH block makes it easy to return or audit error-related data, as well as take other actions. And within the block-specifically, the CATCH portion-you've been able to include a RAISERROR statement in order to re-throw error-related data to the calling application. error handling in stored procedure sql However, with the release of SQL Server 2012, you now have a replacement for RAISERROR, the THROW statement, which makes it easier than ever to capture the error-related data. In this article, we'll look at the TRY…CATCH block used with both the RAISERROR and THROW statements. The examples are based on a table I created in the AdventureWorks2012 sample database, on a local instance of SQL Server 2012. Listing 1 shows the T-SQL script I used to create the LastYearSales table. 123456789101112131415161718 USE AdventureWorks2012;GOIF OBJECT_ID('LastYearSales', 'U') IS NOT NULLDROP TABLE LastYearSales;GOSELECTBusinessEntityID AS SalesPersonID,FirstName + ' ' + LastName AS FullName,SalesLastYearINTOLastYearSalesFROMSales.vSalesPersonWHERESalesLastYear > 0;GO Listing 1: Creating the LastYearSales table The script should be fairly straightforward. I use a SELECT…INTO statement to retrieve data from the Sales.vSalesPerson view and insert it into the newly created table. However, to demonstrate how to handle errors, we need to add one more element to our table: a check constraint that ensures the SalesLastYear value is never less than zero. Listing 2 shows the ALTERTABLE statement I used to add the constraint. 123 ALTER TABLE LastYearSales
how you should implement error handling when you write stored procedures, including when you call them from ADO. The other article, Error Handling in SQL Server - a Background, try catch in sql server 2008 stored procedure example gives a deeper description of the idiosyncrasies with error handling in SQL Server
Try Catch Sql Server 2005
and ADO. That article is in some sense part one in the series. However, you can read this article without
Sql Server Stored Procedure Error Handling Best Practices
reading the background article first, and if you are not a very experienced user of SQL Server, I recommend you to start here. In places there are links to the background article, if you https://www.simple-talk.com/sql/database-administration/handling-errors-in-sql-server-2012/ want more information about a certain issue. Note: this article is aimed at SQL2000 and earlier versions of SQL Server. SQL2005 offers significantly improved methods for error handling with TRY-CATCH. This article is not apt if you are using SQL 2005 or later. I don't have a complete article on error handling for SQL 2005, but I have an unfinished article with a section Jumpstart Error Handling http://www.sommarskog.se/error-handling-II.html that still can be useful. Table of Contents: Introduction The Presumptions A General Example Checking Calls to Stored Procedures The Philosophy of Error Handling General Requirements Why Do We Check for Errors? When Should You Check @@error? ROLLBACK or not to ROLLBACK - That's the Question SET XACT_ABORT ON revisited Error Handling with Cursors Error Handling with Triggers Error Handling with User-Defined Functions Error Handling with Dynamic SQL Error Handling in Client Code What to Do in Case of an Error? Command Timeouts Why is My Error Not Raised? Getting the Return Value from a Stored Procedure Acknowledgements and Feedback Revision History Introduction Error handling in stored procedures is a very tedious task, because T-SQL offers no exception mechanism, or any On Error Goto. All you have is the global variable @@error which you need to check after each statement for a non-zero value to be perfectly safe. If you call a stored procedure, you also need to check the return value from the procedure. In fact, this is so extremely tedious, so you will find that you will have to make compromises and in some situations assume that nothing can go wrong. Still, you cannot just igno
Procedure Input Parameters Output Parameters Try ... Catch Commenting Code Naming Conventions SET NOCOUNT ON DROP Procedure ALTER Procedure Get Free SQL Tips Tutorial Items https://www.mssqltips.com/sqlservertutorial/164/using-try-catch-in-sql-server-stored-procedures/ Introduction Creating Stored Procedures Simple Stored Procedure Input Parameters Output Parameters Try ... Catch Commenting Code Naming Conventions SET NOCOUNT ON DROP Procedure ALTER Procedure Get Free SQL Tips << Previous Next >> By: Greg Robidoux Overview A great new option that was added in SQL Server 2005 was the ability to use the Try..Catch paradigm that exists in other development error handling languages. Doing error handling in SQL Server has not always been the easiest thing, so this option definitely makes it much easier to code for and handle errors. Explanation If you are not familiar with the Try...Catch paradigm it is basically two blocks of code with your stored procedures that lets you execute some code, this is the Try section error handling in and if there are errors they are handled in the Catch section. Let's take a look at an example of how this can be done. As you can see we are using a basic SELECT statement that is contained within the TRY section, but for some reason if this fails it will run the code in the CATCH section and return the error information. CREATE PROCEDURE dbo.uspTryCatchTest AS BEGIN TRY SELECT 1/0 END TRY BEGIN CATCH SELECT ERROR_NUMBER() AS ErrorNumber ,ERROR_SEVERITY() AS ErrorSeverity ,ERROR_STATE() AS ErrorState ,ERROR_PROCEDURE() AS ErrorProcedure ,ERROR_LINE() AS ErrorLine ,ERROR_MESSAGE() AS ErrorMessage; END CATCH << Previous Next >> More SQL Server Solutions Post a comment or let the author know this tip helped. All comments are reviewed, so stay on subject or we may delete your comment. Note: your email address is not published. Required fields are marked with an asterisk (*). *Name *Email Notify for updates *** NOTE *** - If you want to include code from SQL Server Management Studio (SSMS) in your post, please copy t