SQL SERVER 单游标存储过程

SQL SERVER 单游标存储过程模板

USE [PWMS_YANTAI]
GO
 Object  StoredProcedure [dbo].[PWMS_CW_PDA_PICKINGOUT]    Script Date 2017-06-23 94225 
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-----------------------------------------------------------------------------
  1.SYSTEM        동양기전 WMS(창원)
  2.SUBSYSTEM     PDA
  3.PROGRAM ID   DY_WMS_CWPDA.W_PP1U22
  6.DESCRIPTION  PDA 가용재고 이동처리
  7.Author        ZHANG
  8.HISTORY
  ----------------------------------------------------------------------------
                        변     경    사    항
  ----------------------------------------------------------------------------
     IO         NAME        VERSION       DESCRIPTION
  ----------  ------------  ----------  --------------------------------------
  2017-06-23    zhang       1.0       Initialization
  exec [dbo].[PWMS_CW_PDA_PICKINGOUT] 
  ----------------------------------------------------------------------------
 
 CREATE PROCEDURE [dbo].[PWMS_CW_PDA_PICKINGOUT]
    @S_BUKRS    NCHAR(4),
    @S_WERKS    NCHAR(4),
    @S_STOCCD   varchar(4),
    @sPrc       varchar(4),
    --@S_OUTSEQ    NVARCHAR(10),
    --@S_OUTQTY DECIMAL(13,3),
    --@S_OUTDAY    NVARCHAR(20),
    @S_KOMAU NVARCHAR(15),
    @S_USERID   NVARCHAR(20)

    AS

SET NOCOUNT ON
DECLARE
        @V_MSG       VARCHAR(500),
        @V_RTN       VARCHAR(300)   

BEGIN TRAN

BEGIN TRY

    DECLARE @S_OUTSEQ    NVARCHAR(10)
    DECLARE @S_OUTQTY   DECIMAL(13,3)
    DECLARE @S_OUTDAY    NVARCHAR(20)

    DECLARE cur_MOVE  CURSOR FOR

        SELECT  A.BARCD,A.qty,A.JOBDAY          
          FROM CW_PDAQUE A
         WHERE A.PLANT = @S_WERKS
           AND A.BUKRS = @S_BUKRS
           AND A.STL = @s_STOCCD
           AND A.PRC = @sPrc
           AND A.USERID = @s_USERID
           AND A.QTY0
           AND A.STATE ='X'
           AND A.ORDNO = @S_KOMAU
          ORDER BY A.SEQ;

        OPEN cur_MOVE

        FETCH NEXT FROM cur_MOVE INTO
            @S_OUTSEQ,@S_OUTQTY,@S_OUTDAY

            WHILE (@@FETCH_STATUS = 0)
                BEGIN       
                    
                    




    FETCH NEXT FROM cur_MOVE INTO
                                  @sSeq, @sMatcod,@dQty,@sLocidr,@sLocidh,@sLocidd,@IDSEQ
                    END
                    CLOSE cur_MOVE
                    DEALLOCATE cur_MOVE

END TRY
BEGIN CATCH
    SELECT @V_MSG = SUBSTRING(ERROR_MESSAGE(),1,500)
    GOTO ERROR_TRANSACTION
END CATCH


SET NOCOUNT OFF

 ---- 트랜잭션 성공
    SELECT 'OK' ProcFlag, LEFT(@V_RTN, LEN(@V_RTN)-1), @V_MSG

    --적재 Que 완료처리
    UPDATE CW_PDAQUE
       SET STATE='Y'
     WHERE PDAID = @sPdaid;
    
    COMMIT TRAN

    PRINT  '[WMS_CW_PDA_MOVEGOOD] COMMIT 완료'    
    
    GOTO END_BATCH

    ---- 트랜잭션 구문 안에서 실패
ERROR_TRANSACTION

    SELECT 'NG' ProcFlag, @V_MSG
    ROLLBACK TRAN

    PRINT  '[WMS_CW_PDA_MOVEGOOD] ROLLBACK 완료'  

    BEGIN TRAN
        --적재 Que 완료처리
        UPDATE CW_PDAQUE
           SET dsc= '@V_MSG ' + @V_MSG,
               STATE='E'
         WHERE PDAID = @sPdaid
           AND SEQ=@sSeq;

    COMMIT TRAN
    
    BEGIN TRAN
    ROLLBACK TRAN
    
    GOTO END_BATCH

    ---- 트랜잭션 구문 밖에서 실패
ERROR_ACTION

    SELECT 'NG' ProcFlag, @V_MSG

    BEGIN TRAN
        --적재 Que 완료처리
        UPDATE CW_PDAQUE
           SET dsc= @V_MSG,
               STATE='E'    
         WHERE PDAID = @sPdaid;

    COMMIT TRAN

END_BATCH       
···
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 查询速度慢的原因很多,常见如下几种: 1、没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2...
    辉格食品阅读 2,420评论 0 9
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,993评论 19 139
  • 来源:博客园 阿赫瓦里 数据类型是一种属性,用于指定对象可保存的数据的类型,SQL Server中支持多种数据类型...
    _Nullptr阅读 887评论 0 3
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,779评论 18 399
  • oracle存储过程常用技巧 我们在进行pl/sql编程时打交道最多的就是存储过程了。存储过程的结构是非常的简单的...
    dertch阅读 3,514评论 1 12