--临时表
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 常用语法
sqlserver查找 table, view, column select * from information_schema.tables where table_schema='bk' sele ...
- SqlServer常用语法总结
前言 近期公司做一个短信平台,写了一些关于统计方面的存储过程,今天刚好有空总结一下. 统计查询和性能提升 一.使用WITH AS提高性能简化嵌套SQL 首先,感谢@飞洋过海和@宋沄剑,通过阅读他们的博 ...
- Markdown通用的常用语法说明
前言 Markdown 是一种轻量级的 标记语言,语法简洁明了.学习容易,还具有其他很多优点,目前被越来越多的人用来写作使用. Markdown具有一系列衍生版本,用于扩展Markdown的功能(如表 ...
- Markdown简介以及常用语法
Markdown简介以及常用语法 最近发现用markdown记录东西很方便,感觉和emacs的org mode很类似,但是windows下使用emacs不是很方便.特此记录一下markdown常用的语 ...
- Sql常用语法以及名词解释
Sql常用语法以及名词解释 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) D ...
- Markdown常用语法
什么是Markdown Markdown 是一种方便记忆.书写的纯文本标记语言,用户可以使用这些标记符号以最小的输入代价生成极富表现力的文档. 通过Markdown简单的语法,就可以使普通文本内容具有 ...
- 2 hive的使用 + hive的常用语法
本博文的主要内容有: .hive的常用语法 .内部表 .外部表 .内部表,被drop掉,会发生什么? .外部表,被drop掉,会发生什么? .内部表和外部表的,保存的路径在哪? .用于创建一些临时表存 ...
- sql 常用语法汇总
Sql常用语法 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控 ...
- ylb:SQLServer常用系统函数-字符串函数、配置函数、系统统计函数
原文:ylb:SQLServer常用系统函数-字符串函数.配置函数.系统统计函数 ylbtech-SQL Server:SQL Server-SQLServer常用系统函数 -- ========== ...
随机推荐
- Loj #6069. 「2017 山东一轮集训 Day4」塔
Loj #6069. 「2017 山东一轮集训 Day4」塔 题目描述 现在有一条 $ [1, l] $ 的数轴,要在上面造 $ n $ 座塔,每座塔的坐标要两两不同,且为整点. 塔有编号,且每座塔都 ...
- 经常在比特币中看到的merkle树是什么?
区块基础-merkle树 Merkle tree中文叫做梅克尔树,这当然不是一棵真正的植物树,merkle tree是计算机数据结构中的一种树,是由计算机科学家 Ralph Merkle 提出的, ...
- Python:Day05 作业
购物车: product_list = [['iphone6s',5800],['mac book',9800],['coffee',32],['book',80],['bike',1500]] sh ...
- Oracle数据块深入分析总结
http: 最近在研究块的内部结构,把文档简单整理了一下,和大家分享一下.该篇文章借助dump和BBED对数据 库内部结构进行了分析,最后附加了一个用BBED解决ORA-1200错误的小例子.在总结的 ...
- 环境部署(四):Linux下查看JDK安装路径
在安装好Git.JDK和jenkins之后,就需要在jenkins中进行对应的设置,比如在全局工具配置模块,需要写入JDK的安装路径. 这篇博客,介绍几种常见的在Linux中查看JDK路径的方法... ...
- buildroot使用介绍
buildroot是Linux平台上一个构建嵌入式Linux系统的框架.整个Buildroot是由Makefile脚本和Kconfig配置文件构成的.你可以和编译Linux内核一样,通过buildro ...
- java并发线程池---了解ThreadPoolExecutor就够了
总结:线程池的特点是,在线程的数量=corePoolSize后,仅任务队列满了之后,才会从任务队列中取出一个任务,然后构造一个新的线程,循环往复直到线程数量达到maximumPoolSize执行拒绝策 ...
- Mac 小记 — iTerm2、Zsh、Homebrew
前言 写完 "Ubuntu 自动化配置" 这篇文章后,每次连服务器心情指数都上升好几个百分点,于是想着应该将 macOs 的开发环境也梳理梳理,应该会对开发效率有所增益. 1. i ...
- Lambda表达式介绍(转)
刚开始学lambda,lambda与linq的联合使用. Lambda表达式实际上是一个匿名函数.它包含表达式和语句,常用于创建委托或表达式目录树类型.所有Lambda表达式都是用Lambda运算符- ...
- 使用redis实现生产者消费者模式
本次主要分享一下使用redis做缓存队列,实现生产者消费者模式. 首先先来看一下redis提供的列表操作接口.像ListRightPush就和符合队列先进先出的原则. 然后围绕这个列表已下单为例简要实 ...