2009-09-26 17 views
25
CREATE PROCEDURE [dbo].[PL_GEN_PROVN_NO1]   
@GAD_COMP_CODE VARCHAR(2) =NULL, 
@@voucher_no numeric =null output 
AS   
BEGIN 
    DECLARE @NUM NUMERIC 
    DECLARE @PNO NUMERIC        
    SET @PNO = 0 
    DECLARE @PNO1 NUMERIC 
    SET @PNO1=0 

-- begin transaction 

    IF NOT EXISTS (select GLDC_NEXT_PRV_NO 
       FROM GLAS_FINANCIAL_DOCUMENTS   
        WHERE GLDC_COMP_CODE = @GAD_COMP_CODE   
        AND GLDC_DOC_CODE = 'JV') 
    BEGIN 
       RAISERROR ('Error in generating provision number..',16,1) 
       -- ROLLBACK TRANSACTION 
    END 
ELSE 
SELECT @PNO=ISNULL(GLDC_NEXT_PRV_NO,0)+1 
FROM GLAS_FINANCIAL_DOCUMENTS   
WHERE GLDC_COMP_CODE = @GAD_COMP_CODE   
AND GLDC_DOC_CODE = 'JV' 

UPDATE GLAS_FINANCIAL_DOCUMENTS   
SET GLDC_NEXT_PRV_NO = @PNO   
WHERE GLDC_COMP_CODE = @GAD_COMP_CODE   
AND GLDC_DOC_CODE = 'JV' 

set @@[email protected]  
--commit transaction 
END 

このprocでは、try catchの例外処理をどのように処理できますか?SQLストアドプロシージャにtry/catchを追加する方法

+0

その悲しいが、私は仕事2でこれを持っている - 人々は大文字でSQLを書くことを主張! –

答えて

29

here

CREATE PROCEDURE [dbo].[PL_GEN_PROVN_NO1]   
     @GAD_COMP_CODE VARCHAR(2) =NULL, 
     @@voucher_no numeric =null output 
     AS   
    BEGIN 

    begin try 
     -- your proc code 
    end try 

    begin catch 
      -- what you want to do in catch 
    end catch  
    END -- proc end 
27

のTransact-SQLは、C#やC++が原因の取引の追加複雑で、/ catchブロックを試してみてくださいすることを少しトリッキーです。を参照してください。 CATCHブロックは、xact_state()関数をチェックし、コミットできるかロールバックする必要があるかを判断する必要があります。私は私のブログにトピックをカバーしていると私は可能なネストされたトランザクションを含む正確にtry catchブロックでトランザクションを処理する方法を示し記事を、持っている:Exception handling and nested transactions.

create procedure [usp_my_procedure_name] 
as 
begin 
    set nocount on; 
    declare @trancount int; 
    set @trancount = @@trancount; 
    begin try 
     if @trancount = 0 
      begin transaction 
     else 
      save transaction usp_my_procedure_name; 

     -- Do the actual work here 

lbexit: 
     if @trancount = 0 
      commit; 
    end try 
    begin catch 
     declare @error int, @message varchar(4000), @xstate int; 
     select @error = ERROR_NUMBER(), 
       @message = ERROR_MESSAGE(), @xstate = XACT_STATE(); 
     if @xstate = -1 
      rollback; 
     if @xstate = 1 and @trancount = 0 
      rollback 
     if @xstate = 1 and @trancount > 0 
      rollback transaction usp_my_procedure_name; 

     raiserror ('usp_my_procedure_name: %d: %s', 16, 1, @error, @message) ; 
     return; 
    end catch 
end 
2

うん - あなたができるにも巣のtry catchステートメントを以下のように:

BEGIN TRY 
SET @myFixDte = CONVERT(datetime, @myFixDteStr,101) 
END TRY 
BEGIN CATCH 
    BEGIN TRY 
     SET @myFixDte = CONVERT(datetime, @myFixDteStr,103) 
END TRY 
BEGIN CATCH 
    BEGIN TRY 
     SET @myFixDte = CONVERT(datetime, @myFixDteStr,104) 
    END TRY 
    BEGIN CATCH 
     SET @myFixDte = CONVERT(datetime, @myFixDteStr,105) 
    END CATCH 
END CATCH END CATCH 
0
Create Proc[usp_mquestions] 
( 
@title nvarchar(500), --0 
@tags nvarchar(max), --1 
@category nvarchar(200), --2 
@ispoll char(1), --3 
@descriptions nvarchar(max), --4 
)    
AS 
BEGIN TRY 




BEGIN 
DECLARE @message varchar(1000); 
DECLARE @tempid bigint; 

IF((SELECT count(id) from [xyz] WHERE [email protected])>0) 
BEGIN 
SELECT 'record already existed.'; 
END 
ELSE 
BEGIN    


if @id=0 
begin 
select @tempid =id from [xyz] where [email protected]; 

if @tempid is null 
BEGIN 
     INSERT INTO xyz 
     (entrydate,updatedate) 
     VALUES 
     (GETDATE(),GETDATE()) 

     SET @[email protected]@IDENTITY; 
END 
END 
ELSE 
BEGIN 
set @[email protected] 
END 
if @tempid>0 
BEGIN 

    -- Updation of table begin-- 


UPDATE tab_questions 
set [email protected], --0 
[email protected], --1 
[email protected], --2 
[email protected], --3 
[email protected], --4 
[email protected], --5 

WHERE [email protected] ; --9 ; 


IF @id=0 
BEGIN 
SET @message= 'success:Record added successfully:'+ convert(varchar(10), @tempid) 
END 
ELSE 
BEGIN 
SET @message= 'success:Record updated successfully.:'+ convert(varchar(10), @tempid) 

END 
END 
ELSE 
BEGIN 
SET @message= 'failed:invalid request:'+convert(varchar(10), @tempid) 
END 

END 
END 

END TRY 
BEGIN CATCH 
    SET @message='failed:'+ ERROR_MESSAGE(); 
END CATCH 
SELECT @message; 
+0

解答に付随する説明がうれしいです。 –

関連する問題