SQL中存储过程中使用事务,并且加入异常处理机制.

--存储过程中使用事务,并且加入异常处理机制.
-- =============================================
CREATE PROCEDURE [dbo].[UP_Orders_Import]
AS
BEGIN
	BEGIN TRAN  --开启事务
		BEGIN TRY  
			
			SELECT 1/0
		
			COMMIT TRAN  --提交事务
		END TRY  
    BEGIN CATCH  
        DECLARE  
            @ErrorMessage NVARCHAR(4000) ,  
            @ErrorNumber INT ,  
            @ErrorSeverity INT ,  
            @ErrorState INT ,  
            @ErrorLine INT ,  
            @ErrorProcedure NVARCHAR(200) ;  
   
        SELECT  
                @ErrorNumber=ERROR_NUMBER(),@ErrorSeverity=ERROR_SEVERITY(),  
                @ErrorState=ERROR_STATE(),@ErrorLine=ERROR_LINE(),  
                @ErrorProcedure=ISNULL(ERROR_PROCEDURE(),'-') ;  
        SELECT  
                @ErrorMessage=N'Error %d, Level %d, State %d, Procedure %s, Line %d, '  
                +'Message: '+ERROR_MESSAGE() ;  
        RAISERROR   
        (  
		   @ErrorMessage,   
		   @ErrorSeverity,   
		   1,                 
		   @ErrorNumber,    -- parameter: original error number.  
		   @ErrorSeverity,  -- parameter: original error severity.  
		   @ErrorState,  -- parameter: original error state.  
		   @ErrorProcedure, -- parameter: original error procedure name.  
		   @ErrorLine       -- parameter: original error line number.  
		) ;  
        ROLLBACK TRAN  --回滚事务
    END CATCH  
END

  sql事务注意点:

        DECLARE @Referenznummer NVARCHAR(MAX)
        SET @Referenznummer = '934590-AE1023-1'
        
        BEGIN TRAN
        BEGIN TRY	
        
          DECLARE @returnValue INT  
          SET @returnValue = 11110
        
             --(1)、变量在事务中是不会进行回滚的;默认值虽然是11110
            SET @returnValue = 1  
          
        
            IF (
                NOT EXISTS ( SELECT 1
                             FROM   tbOrder
                             WHERE  Referenznummer = @Referenznummer )
               ) 
                BEGIN  
				
				    --(2)、出现异常后,直接终止下面的代码,跳转到CATCH代码块中.
                    SELECT  10 / 0
				    --begin
                    SELECT  @@ERROR
                    SELECT  100
                    IF (@@error <> 0)   --此语句在try catch中是捕获不到的。
                        BEGIN  
                            SET @returnValue = 0  
                        END  
					--end
                END  
            ELSE 
                BEGIN  
                    SET @returnValue = 3  
                END
            COMMIT TRAN  
        END TRY		
        BEGIN CATCH	
            PRINT 'error'
            --SET @returnValue = 0  
            ROLLBACK TRAN
        END CATCH
    
        SELECT  @returnValue
        --RETURN @returnValue  

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏杨建荣的学习笔记

使用copy命令解决LONG类型的困扰(r2第24天)

在oracle的数据类型中,long类型算是一个比较另类的典型,早就不建议使用了,但是在数据字典里还是能看到long 类型的影子。 如果在一些工作中碰到long...

35160
来自专栏乐沙弥的世界

SQL基础--> 约束(CONSTRAINT)

约束是表、列级的强制规定、是防止那些无效或有问题的数据输入到表中。当对该表进行DML

9420
来自专栏沃趣科技

innodb存储引擎锁的实现

通常,我们在95%以上的MySQL使用场景中,从一定程度上来讲,就是在使用InnoDB存储引擎,很多时候我们选择使用InnoDB存储引擎的原因,就是因为它支持高...

15650
来自专栏java工会

十个mysql语句的优化方法

20960
来自专栏Java呓语

第13.1.1章 语法解释ALTER DATABASE

ALTER DATABASE 允许修改数据库的特征,所有关于数据库的特征都存储在db.opt文件中。你必须先具备该数据库的ALTER特权,才能完成对数据库的AL...

8510
来自专栏乐沙弥的世界

SQL基础--> 数据处理(DML、RETURNING、MERGE INTO)

--=================================================

9620
来自专栏行者常至

pgsql编写触发器

7200
来自专栏PHP在线

MySQL索引类型一览 让MySQL高效运行起来

索引是快速搜索的关键。MySQL索引的建立对于MySQL的高效运行是很重要的。下面介绍几种常见的MySQL索引类型。 在数据库表中,对字段建立索引可以大大提高...

35650
来自专栏java系列博客

关于ORACLE merge into 的两个常见错误

1.9K30
来自专栏黑泽君的专栏

day04_MySQL学习笔记_01

数据库(DataBase,DB):指长期保存在计算机的存储设备上,按照一定规则组织起来,可以被各种用户或应用共享的数据集合。(文件系统)

8110

扫码关注云+社区

领取腾讯云代金券