--临时表
IF OBJECT_ID('tempdb..#Entry') is not null
BEGIN
  DROP TABLE #Entry
 
END
-----------------------------------------------------
 
--创建触发器
 ALTER TRIGGER [dbo].[icstockbill_ins]
   ON  [dbo].[ICStockBill]
   AFTER insert
AS 
BEGIN
SET NOCOUNT ON;
    declare  @ftrantype int,@Finterid int 
declare @text varchar(255)
declare @fbillerid int
    select @ftrantype=ftrantype,@Finterid=finterid   from inserted
   if @ftrantype=1  
      begin
         exec [采购申请单执行信息更新] @Finterid
          
 
      end 
 
 
      end
--------------------------------------------------------------
 
--创建存储过程
 
ALTER PROC lj_bom_wanjue @fitemid int ,@flevel int
AS
begin
DECLARE CURSOR FOR 
SELECT FITEMID,FQTY  INTO #tmp FROM dbo.BZX_BOMEntry  WHERE FID = 
(SELECT MAX(fid) FROM dbo.BZX_BOM WHERE FITEMID = @fitemid)
SELECT *FROM #tmp
DROP TABLE #tmp
END
 
 
EXEC   lj_bom_wanjue 78940, 1
----------------------------------------------------
--游标
 CREATE  table #t(fitemid INT)
 DECLARE @fitemid INT
 DECLARE lj_test CURSOR FOR
 SELECT TOP 50 FItemID FROM dbo.t_ICItem 
 OPEN lj_test 
 FETCH NEXT FROM lj_test INTO @fitemid
while (@@fetch_status=0)
 BEGIN
 INSERT INTO #t(fitemid) VALUES (@fitemid)
  --PRINT @fitemid
  FETCH NEXT FROM lj_test INTO @fitemid
 END
 CLOSE lj_test
 DEALLOCATE lj_test
 SELECT *FROM #t
DROP TABLE  #t
 
------------------------------------------------------------
--BOM嵌套
  declare   @lev   int,@liaohao   varchar(30)   
  select   @MID='2',@levs=1   
  declare   @t   table(物料ID号   varchar(30),序号   int,物料父ID号   varchar(30),levs   int)   
  insert   @t   select   物料ID号 ,序号,物料父ID号,@levs   from   BOM   where   物料ID号=@lMID      
  while   @@rowcount<>0   
  begin   
        set   @levs=@levs+1   
        insert   @t   select  物料ID号,序号,物料父ID号,@levs  from   BOM     
        where   物料父ID号   in(select    物料ID号   from   @t   where   levs=@levs-1)   
  end   
    
  select   *   from   @t   order   by   levs 
 
 
 
---------------------------------------------------------------
 
--临时表
insert into #bzxbom(fmbitemid,fitemid,fqty,fyt,fth,fisty,fgx,fnote,flev,fismm,fpz ) select @fcpitmeid,@fitemid,@fqty,@fyt,@fth,@fisty,@fyt,@FNOTE,cast(@fmb as varchar(255)),@fismm,@fpz 
      if exists(select 1 from BZX_BOM where FITEMID = @fitemid )
 
 
-------------------------------------------------------------
--存储过程调用存储过程
 
 exec GetICMaxNum 'icstockbill' ,@fqoutinterid output ,1,@fbiller
 exec LJ_GetBillNo  29,@fqoutbillno output
 
 select @fqoutinterid as finterid,IDENTITY(int,1,1) as fentryid,'0' as fbrno,a.FItemID,a.FBatchNo,a.FQty,a.FStockID,b.FUnitID,a.FQty as Fauxqty,'PLM调拨库存' as fnote,a.FStockPlaceID,14036 as FPlanMode
 into #lj_qout 
 from ICInventory a inner join t_ICItem b on a.FItemID =b.FItemID 
 where b.FNumber = @foldnumber and b.FDeleted =0 and a.FQty >0
 
 INSERT INTO ICStockBillEntry (FInterID,FEntryID,FBrNo,FItemID,FBatchNo,FQty,FDCStockID,FUnitID,Fauxqty,Fnote,FDCSPID,FPlanMode)  
 SELECT * from #lj_qout
 
 drop table #lj_qout
 
 INSERT INTO ICStockBill(FInterID,FBillNo,FBrNo,FTranType,FCancellation,FStatus,FUpStockWhenSave,FROB,Fdate,FDeptID,Fuse,FCheckDate,FFManagerID,FSManagerID,FBillerID,FHeadSelfB0941 ) 
 SELECT @fqoutinterid,@fqoutbillno,'0',29,0,0,0,1,convert(varchar(10),GETDATE(),120),65522,'',Null,10147,10147,16740,@fplmwldh
 
 EXEC p_UpdateBillRelateData 29,@fqoutinterid,'ICStockBill','ICStockBillEntry' 
 
 
 
 ----------------------------------------------------------
 
--存储过程返回值 
ALTER proc [dbo].[LJ_GetBillNo]
@ClassType  VARCHAR(50),
@RBillNo       VARCHAR(50)   OUTPUT
AS
BEGIN
DECLARE @BillNo varchar(50) 
DECLARE @FullBillNo varchar(50) 
DECLARE @BillID int 
DECLARE @TmpID INT 
DECLARE @BillIDLen int 
DECLARE @NOBillStr varchar(5000) 
DECLARE @BillStr varchar(5000) 
DECLARE @SCRBillNO varchar(500) 
 
SET @FullBillNo = ''
set  @BillNo=''
--取单据编号1
SELECT @BillNo = a.fprojectval 
   FROM t_BillCodeRule a
   LEFT OUTER JOIN t_option e ON a.fprojectid = e.fprojectid AND a.fformatindex = e.fid
   LEFT OUTER JOIN t_checkproject b ON a.fbilltype = b.fbilltypeid AND a.fprojectval = b.ffield
WHERE a.fbilltypeid = @ClassType 
      AND a.fprojectID = 1
 
--取单据编号2
SELECT @BillIDLen = a.flength,
               @BillID = a.fprojectval  
   FROM t_BillCodeRule a
   LEFT OUTER JOIN t_option e ON a.fprojectid = e.fprojectid AND a.fformatindex = e.fid
   LEFT OUTER JOIN  t_checkproject b ON a.fbilltype = b.fbilltypeid AND a.fprojectval = b.ffield
WHERE a.fbilltypeid = @ClassType 
      AND a.fprojectID = 3
 
--设置返回值
SET @FullBillNo = (@BillNo + REPLICATE('0' , @BillIDLen - LEN(CAST(@BillID AS VARCHAR(50)))) + CAST(@BillID AS VARCHAR(50)))
 
BEGIN TRAN
 
-- 更新流水号  
SET @TmpID = (SELECT FID 
                              FROM t_BillCodeRule WITH(READUNCOMMITTED) 
                           WHERE fbilltypeid = @ClassType 
                                 AND fprojectid = 3)
 
UPDATE t_BillCodeRule 
       SET fprojectval = fprojectval + 1 ,
               flength = CASE WHEN (flength - LEN(fprojectval + 1))  >= 0
                                         THEN flength 
                                          ELSE LEN(fprojectval + 1)
                               END 
WHERE FID = @TmpID 
 
UPDATE ICBillNo 
       SET FCurNo = (SELECT TOP 1 ISNULL(fprojectval - 1 , 1) 
                                   FROM t_BillCodeRule 
                                WHERE fprojectid = 3 
                                      AND fbilltypeid = @ClassType) 
WHERE fbillid = @ClassType
 
-- 更新注释流水号
SET @BillID = @BillID + 1
UPDATE ICBillNo 
       SET FDesc = @BillNo + '+' + REPLICATE('0' , @BillIDLen - LEN(CAST(@BillID AS VARCHAR(50)))) + CAST(@BillID  AS VARCHAR(50))
WHERE FBillID = @ClassType
  
IF @@error = 0
  BEGIN
          SELECT @RBillNo = @FullBillNo   
          COMMIT
  END
 ELSE
      BEGIN
               ROLLBACK
               SELECT @RBillNo = ''
      END
RETURN
 
END

sqlserver常用语法的更多相关文章

  1. sqlserver 常用语法

    sqlserver查找 table, view, column select * from information_schema.tables where table_schema='bk' sele ...

  2. SqlServer常用语法总结

    前言 近期公司做一个短信平台,写了一些关于统计方面的存储过程,今天刚好有空总结一下. 统计查询和性能提升 一.使用WITH AS提高性能简化嵌套SQL 首先,感谢@飞洋过海和@宋沄剑,通过阅读他们的博 ...

  3. Markdown通用的常用语法说明

    前言 Markdown 是一种轻量级的 标记语言,语法简洁明了.学习容易,还具有其他很多优点,目前被越来越多的人用来写作使用. Markdown具有一系列衍生版本,用于扩展Markdown的功能(如表 ...

  4. Markdown简介以及常用语法

    Markdown简介以及常用语法 最近发现用markdown记录东西很方便,感觉和emacs的org mode很类似,但是windows下使用emacs不是很方便.特此记录一下markdown常用的语 ...

  5. Sql常用语法以及名词解释

    Sql常用语法以及名词解释 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) D ...

  6. Markdown常用语法

    什么是Markdown Markdown 是一种方便记忆.书写的纯文本标记语言,用户可以使用这些标记符号以最小的输入代价生成极富表现力的文档. 通过Markdown简单的语法,就可以使普通文本内容具有 ...

  7. 2 hive的使用 + hive的常用语法

    本博文的主要内容有: .hive的常用语法 .内部表 .外部表 .内部表,被drop掉,会发生什么? .外部表,被drop掉,会发生什么? .内部表和外部表的,保存的路径在哪? .用于创建一些临时表存 ...

  8. sql 常用语法汇总

    Sql常用语法 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控 ...

  9. ylb:SQLServer常用系统函数-字符串函数、配置函数、系统统计函数

    原文:ylb:SQLServer常用系统函数-字符串函数.配置函数.系统统计函数 ylbtech-SQL Server:SQL Server-SQLServer常用系统函数 -- ========== ...

随机推荐

  1. Linux操作系统有什么吸引力,在程序员中这么受欢迎?

    Linux操作系统有什么吸引力,在程序员中这么受欢迎? 在过去的几十年里,操作系统已经取得了很大的进步.曾经由微软Windows或苹果MacOS主导的操作系统,如今已不再是常态.千禧年之后,随着人们对 ...

  2. 5.01-requests_auth

    import requests # 发送post请求 data = { } response = requests.post(url, data=data) # 内网 需要 认证 auth = (us ...

  3. [CQOI2018]破解D-H协议

    嘟嘟嘟 这不就是个bsgs板儿嘛. 顺便就复习了一下bsgs和哈希表. 头一次觉得我的博客这么好用,一下就懂了:数论学习笔记之高次不定方程 这里再补充几点: 1.关于这一段代码: int S = sq ...

  4. 转://Linux下误删除/home目录的恢复方法

    一般情况下,我们在安装Oracle数据库的时候,都会创建一个Oracle用户,用该用户来安装和管理Oracle.Oracle用户的根目录就是/home/oracle. 通常安装Oracle数据库是按照 ...

  5. ASM problem : ORA-15001: diskgroup "DGROUP1" does not exist or is not mounted ORA-15040: diskgroup is incomplete

    ============================================================= mos中的详细解释: ODA: After Apply ODA 12.2.1 ...

  6. Python IDLE 增加清屏功能

    (Python2,Python3 通用) 保存如下代码到 ClearWindow.py """ Clear Window Extension Version: 0.2 A ...

  7. Spring Boot设置上传文件大小

    可以使用配置文件配置,也可以使用Bean在启动类中配置 配置文件为application.properties格式: spring.http.multipart.maxFileSize=10Mb sp ...

  8. Django 分页器

    Django作为Python Web开发框架的一哥,提供了企业级网站开发所需要的几乎所有功能,其中就包括自带分页功能.利用Django自带的Paginator类,我们可以很轻松地实现分页.Django ...

  9. Luogu P1776 宝物筛选_NOI导刊2010提高(02)(多重背包模版)

    传送门 多重背包板子题, 多重背包就是每种东西有好几个,可以把它拆分成一个一个的01背包 优化:二进制拆分(拆成1+2+4+8+16+...) 比如18=1+2+4+8+3,可以证明18以内的任何数都 ...

  10. CountDownLatch和CyclicBarrier模拟同时并发请求

    有时候要测试一下某个功能的并发能力,又不要想借助于其他测试工具,索性就自己写简单的demo模拟一个并发请求就最方便了.如果熟悉jemter的测试某接口的并发能力其实更专业,此处只是自己折腾着玩. Co ...