USE [GalaxyPointDB24]
GO
/****** Object:  StoredProcedure [dbo].[sp_zy_Process_scrap]    Script Date: 11/26/2015 08:47:53 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO

--2015-08-24 Ht 建立
--功能:BPM_scrap 数据同步功能
--exec sp_zy_Process_scrap 219

ALTER procedure [dbo].[sp_zy_Process_scrap]

@OwnerUserAccount nvarchar(36),          --流程申请人帐号
@SubFlowGuid nvarchar(36),           --流程Guid
@scrap_id nvarchar(36),               --scrap_id
@scrap_version nvarchar(20)           --scrap_version

as
DECLARE @SubTaskId int                --子流程TaskId
DECLARE @FlowCatId int      --流程分类Id
DECLARE @FlowCatName nvarchar(100)      --流程分类名称
DECLARE @FlowName nvarchar(100)       --流程名称
DECLARE @OwnerUserId int     --子流程申请人Id
DECLARE @OwnerUserName nvarchar(100)  --申请人姓名
DECLARE @CompanyId int             --申请人公司Id
DECLARE @NodeId int          --节点Id
DECLARE @NodeName nvarchar(200)    --节点名称
 BEGIN
  BEGIN TRANSACTION
  SET NOCOUNT ON; 
  
  
  -- scrap Get
  --select * into ZYSCRBC from ZY_scrap_m where RBC01 = @scrap_id
  --select * into ZYSCRBD from ZY_scrap_s where RBD01 = @scrap_id
  
  -- scrap Get
  insert into ZY_scrap_m ([TaskId],[ACondom],[COMPANY],[CREATOR],[RBC01]
    ,[RBC02],[RBC03],[RBC04],[RBC05],[RBC06],[RBC07],[RBC08],[RBC09]
          ,[RBC10],[RBC11],[RBC12],[RBC13],[RBC14],[RBC15],[RBC16],[RBC17]
          ,[RBC18],[RBC19],[RBC20],[RBC21],[RBC22],[RBC23]
          ,[CONFORM_DATE],[CONFORM_NAME],[CONFORM_CODE]
          ,[LOCK_CODE],[LOCK_NAME],[LOCK_DATE])
        select [TaskId],[ACondom],[COMPANY],[CREATOR],[RBC01]
    ,[RBC02],[RBC03],[RBC04],[RBC05],[RBC06],[RBC07],[RBC08],[RBC09]
          ,[RBC10],[RBC11],[RBC12],[RBC13],[RBC14],[RBC15],[RBC16],[RBC17]
          ,[RBC18],[RBC19],[RBC20],[RBC21],[RBC22],[RBC23]
          ,[CONFORM_DATE],[CONFORM_NAME],[CONFORM_CODE]
          ,[LOCK_CODE],[LOCK_NAME],[LOCK_DATE]
        from ZYSCRBC where RBC01 = @scrap_id and RBC17 = @scrap_version

insert into ZY_scrap_s ([TaskId]
            ,[GridOrder],[COMPANY],[CREATOR],[RBD01],[RBD02]
            ,[RBD03],[RBD04],[RBD05],[RBD06],[RBD07] ,[RBD08],[RBD09],[RBD10]
            ,[RBD11],[RBD12],[RBD13],[RBD14] ,[RBD15],[RBD16],[RBD17],[RBD18]
            ,[RBD19],[RBD20],[RBD21],[RBD22],[RBD23]
            ,[RBD24],[RBD25],[RBD26],[RBD27],[RBD28],[RBD29],[BFL])
        select [TaskId]
            ,[GridOrder],[COMPANY],[CREATOR],[RBD01],[RBD02]
            ,[RBD03],[RBD04],[RBD05],[RBD06],[RBD07] ,[RBD08],[RBD09],[RBD10]
            ,[RBD11],[RBD12],[RBD13],[RBD14] ,[RBD15],[RBD16],[RBD17],[RBD18]
            ,[RBD19],[RBD20],[RBD21],[RBD22],[RBD23]
            ,[RBD24],[RBD25],[RBD26],[RBD27],[RBD28],[RBD29],[BFL]
        from ZYSCRBD where RBD01 = @scrap_id and RBD23 = @scrap_version

--获取流程信息
  SELECT @FlowCatId = a.FlowCatId,@FlowCatName = a.FlowCatName,@FlowName = b.FlowName from SysBpmDProcessCategory a inner join
  (SELECT FlowCatId,FlowGuid,FlowName from SYSBPMDProcess where FlowGuid = @SubFlowGuid) b on a.FlowCatId = b.FlowCatId ORDER BY a.FlowCatId DESC
  
  --获取节点信息
  SELECT @NodeId = NodeId,@NodeName = NodeName FROM SYSBPMDNode WHERE FlowGuid = @SubFlowGuid AND NodeType = 0 ORDER BY FlowGuid DESC
  --获取提交人信息(必须使用UserId)
  SELECT @OwnerUserId = UserId, @OwnerUserName = UserDspName,@CompanyId = CompanyId FROM SYS_USer WHERE UserAccount = @OwnerUserAccount ORDER BY UserId DESC
  IF (@OwnerUserId IS NULL)
  BEGIN
  RAISERROR ('报废系统 触发工作流存储过程中 ''@OwnerUserId''变量没有获取到发起人ID无法触发流程' , 16, 1) WITH NOWAIT
  ROLLBACK TRANSACTION
  RETURN -1
  END
  
  --插入任务表数据
  INSERT INTO SYSBPMITask(TaskName,FlowCatId,FlowCatName,FlowGuid,FlowName,OwnerUserId,OwnerUserName,OperatorUserId,OperatorUserName,SubmissionDate,
  FinishDate,[Description],SerialNo,[Status],Priority,CompanyId,Active,Creater,CreateTime,Updater,UpdateTime)
  VALUES(@FlowName,@FlowCatId,@FlowCatName,@SubFlowGuid,@FlowName,@OwnerUserId,@OwnerUserName,@OwnerUserId,@OwnerUserName,GETDATE(),NULL,'报废系统自动触发流程',
  '',0,0,@CompanyId,1,@OwnerUserId,GETDATE(),@OwnerUserId,GETDATE())
  --set @SubTaskId = @@identity
  SET @SubTaskId=SCOPE_IDENTITY()
  
  --插入过程表数据
  INSERT INTO SYSBPMIProc(TaskId,FlowCatId,FlowCatName,FlowGuid,FlowName,NodeId,NodeName,NodeType,ActionLinkId,ActionLinkName,HandlerUserId,HandlerUserName,
  ArrivalDate,OpenDate,FinishDate,Finished,FormFile,IsShare,IsRecede,IsAsk,RecedeFromProcId,Comment,AgentUserId,AgentUserName,OperatorUserId,OperatorUserName,
  OwnerUserId,OwnerUserName,CompanyId,Active,Creater,CreateTime,Updater,UpdateTime)
  VALUES(@SubTaskId,@FlowCatId,@FlowCatName,@SubFlowGuid,@FlowName,@NodeId,@NodeName,0,0,'',@OwnerUserId,@OwnerUserName,GETDATE(),NULL,NULL,0,'',0,0,0,0,'',0,'',@OwnerUserId,
  @OwnerUserName,@OwnerUserId,@OwnerUserName,@CompanyId,1,@OwnerUserId,GETDATE(),@OwnerUserId,GETDATE())
  
  -- Update
  --Update ZY_scrap_m set TaskId = @SubTaskId, ACondom = 'DEMO', COMPANY = 'DEMO', CREATOR ='Auto_001' where RBC01 = @scrap_id
  --Update ZY_scrap_s set TaskId = @SubTaskId, COMPANY = 'DEMO', CREATOR ='Auto_001' where RBD01 = @scrap_id
  
  Update ZY_scrap_m set TaskId = @SubTaskId, ACondom = 'DEMO', COMPANY = 'DEMO' where RBC01 = @scrap_id and RBC17 = @scrap_version
  Update ZY_scrap_s set TaskId = @SubTaskId, COMPANY = 'DEMO' where RBD01 = @scrap_id and RBD23 = @scrap_version
  
  -- Used setting
  declare @RBC14 nvarchar(10)
  declare @RBC15 nvarchar(10)
  declare @RBC16 nvarchar(10)
  declare @RBC19 nvarchar(50)   --type
  declare @RBC20 nvarchar(50)   --reason
  declare @RBC21 nvarchar(50)
  declare @RBC23 nvarchar(50)
  
  select @RBC14 = RBC14, @RBC15 = RBC15, @RBC16 = RBC16, @RBC21 = RBC21, @RBC23 = RBC23 from ZY_scrap_m where RBC01 = @scrap_id and RBC17 = @scrap_version
  
  set @RBC19 = (select top 1 case RBC19
                             when 'C' then '成品'
                             when 'B' then '半成品'
                             when 'Y' then '原料'
                             when 'H' then '耗材'
                             END
                      from ZY_scrap_m where RBC01 = @scrap_id and RBC17 = @scrap_version)
       
   set @RBC20 = (select top 1 case RBC20
                             when 'C' then '正常损耗'
                             when 'E' then '工程损耗'
                             when 'P' then '品质异常'
                             END
                      from ZY_scrap_m where RBC01 = @scrap_id and RBC17 = @scrap_version)      
  
  Update ZY_scrap_m set
  RBC14 = (select top 1 UserId from Sys_User where UserAccount = @RBC14),
  RBC15 = (select top 1 UserId from Sys_User where UserAccount = @RBC15),
  RBC16 = (select top 1 UserId from Sys_User where UserAccount = @RBC16),
  RBC19 = @RBC19,
  RBC20 = @RBC20,
  RBC21 = (select top 1 UserId from Sys_User where UserAccount = @RBC21),
  RBC23 = (select top 1 UserId from Sys_User where UserAccount = @RBC23)
  where RBC01 = @scrap_id and RBC17 = @scrap_version
  
  
     -- Update TaskName
  UPDATE SysBpmITask SET [TaskName] = [TaskName] +(@scrap_id + '-' + @scrap_version) WHERE [TaskId] = @SubTaskId
  
  -- fLag setting
  UPDATE ZYSCRBC Set Flag_ID = 'Y' WHERE RBC01 = @scrap_id and RBC17 = @scrap_version
  
  IF @@error <> 0 --发生错误
  BEGIN
   ROLLBACK TRANSACTION
   RETURN -1
  END
  ELSE
  BEGIN
   COMMIT TRANSACTION
   RETURN @SubTaskId    --执行成功
  END
  COMMIT TRANSACTION
 END

sp_sys_ERPTrigger_base的更多相关文章

随机推荐

  1. 基于DES算法加密的防撞库密码系统项目总结

    项目内容:基于DES算法加密的防撞库密码系统 小组名:zqhzkzkj 目标:1.对用户输入的8位字符进行DES加密,要求用户输入8位密钥 2.对于不同的网站,不同的用户名生成不同的密码 小组成员:周 ...

  2. Java知多少(19)访问修饰符(访问控制符)

    Java 通过修饰符来控制类.属性和方法的访问权限和其他功能,通常放在语句的最前端.例如: 1 public class className { 2 // body of class 3 } 4 pr ...

  3. 前端bower使用

    Bower是一个客户端技术的软件包管理器,是由twitter推出的.它可用于搜索.安装和卸载如JavaScript.HTML.CSS之类的网络资源.其他一些建立在Bower基础之上的开发工具,如Yeo ...

  4. ORACLE 12C PDB 维护基础介绍

    来自:http://www.xifenfei.com/2013/05/oracle-12c-pdb-%E7%AE%A1%E7%90%86%E4%BB%8B%E7%BB%8D1.html CDB和PDB ...

  5. fzuoj Problem 2179 chriswho

    http://acm.fzu.edu.cn/problem.php?pid=2179 Problem 2179 chriswho Accept: 57    Submit: 136 Time Limi ...

  6. const 关键字及作用

    1.const 修饰一般常量,可以把变量变成常量 例如: int  num=10; num=100; printf(“num=%d\n”,num); 输出的来得值为:100: 但是如果const in ...

  7. hdu4918 Query on the subtree

    树分治,设当前树的分治中心为x,其子树分治中心为y,则设father[y]=x,分治下去则可以得到一颗重心树,而且树的深度是logn. 询问操作(x,d),只需要查询重心树上x到重心树根节点上的节点的 ...

  8. php 迭代器

    迭代器(Iterator)模式,又叫做游标(Cursor)模式.GOF给出的定义为:提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节. 百度百科: http: ...

  9. 【linux】终端直接执行py文件,不需要python命令

    先将终端所在路径切换到python脚本文件的目录下然后给脚本文件运行权限,一般755就OK,如果完全是自己的私人电脑,也不做服务器什么的,给777的权限问题也不大(具体权限含义参考chmod指令的介绍 ...

  10. jquery冲突细节

    使用jquery报一个错误,之前也遇到过,今天记录下来,方便以后使用 Uncaught TypeError: Object #<Object> has no method 'test' 这 ...