当前位置:Gxlcms > 数据库问题 > 一个复杂的SQL存储过程例子

一个复杂的SQL存储过程例子

时间:2021-07-01 10:21:17 帮助过:2人阅读

<Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
ALTER PROCEDURE [dbo].[sp_FactoryAllocationFind]
--[业务日期]
@btime datetime,
@etime datetime,
--[调出工厂]
@warehouseOut varchar(50),
--[调入工厂]
@warehouseIn varchar(50),
--[调拨单号]
@sn varchar(50),
--[调拨入库单号]
@snIn varchar(50),
--[调拨取消单号]
@snCancel varchar(50),
--[说明]
@remark varchar(200),
--[包裹信息]
@package varchar(200),
--[状态]
@status varchar(50),
--[审批状态]
@auditStatus varchar(50),
--[在途未处理]
@intransit bit
AS
BEGIN
declare @sqltable table(F_SN varchar(50))   --这个用了临时表
if(@snIn IS NOT NULL) or (@intransit IS NOT NULL)
insert into @sqltable(F_SN)(select F_AllocationSN from dbo.T_Warehouse_FactoryAllocationIn 
where F_SN = @snIn or F_InTransitStatus = @intransit)   --临时表的存储
    else if(@snCancel IS NOT NULL)
insert into @sqltable(F_SN)(select F_AllocationSN from dbo.T_Warehouse_FactoryAllocationCancel 
where F_SN = @snCancel) 
    else if(@package IS NOT NULL)
        insert into @sqltable(F_SN)(select F_SN from dbo.T_Warehouse_FactoryAllocation 
where F_ID = (        
select F_AllocationID from dbo.T_Warehouse_FactoryAllocationDetail 
where CHARINDEX(@package,F_Version)>0 or CHARINDEX(@package,F_PackageBarcode)>0 or CHARINDEX(@package,F_ProductName)>0))
else
insert into @sqltable(F_SN)(select F_SN from dbo.T_Warehouse_FactoryAllocation 
where (ISNULL(@btime,‘‘)=‘‘ or  F_ServiceTime>=@btime) 
and (ISNULL(@etime,‘‘)=‘‘ or  F_ServiceTime< DATEADD(dd,1,@etime)) 
and (ISNULL(@warehouseOut,‘‘)=‘‘ or  CHARINDEX(@warehouseOut, F_OutFactoryName)>0)
and (ISNULL(@warehouseIn,‘‘)=‘‘ or  CHARINDEX(@warehouseIn, F_InFactoryName)>0)
and (ISNULL(@sn,‘‘)=‘‘ or  CHARINDEX(@sn,F_SN)>0) 
and (ISNULL(@remark,‘‘)=‘‘ or  CHARINDEX(@remark,F_Remark)>0) 
and (ISNULL(@status,‘‘)=‘‘ or  CHARINDEX(@status,F_Status)>0) 
and (ISNULL(@auditStatus,‘‘)=‘‘ or  CHARINDEX(@auditStatus,F_Status)>0))

select *
from(
select F_ID as ID, ‘调出‘ as 类型, F_SN as 调拨单号, F_SN as 单号, F_ServiceTime as 业务日期, F_OutFactoryName as 调出工厂, F_OutWarehouseName as 调出仓库,
F_InFactoryName as 调入工厂,F_InWarehouseName as 调入仓库, F_CreationTime as 创建时间, F_Creator as 创建人, F_Status as 状态,
F_AuditStatus as 审批状态
from dbo.T_Warehouse_FactoryAllocation
union
select F_ID as ID, ‘调入‘ as 类型, F_AllocationSN as 调拨单号,  F_SN as 单号, F_ServiceTime as 业务日期, ‘‘ as 调出工厂, ‘‘ as 调出仓库,
‘‘ as 调入工厂,‘‘ as 调入仓库, F_CreationTime as 创建时间, F_Creator as 创建人, F_Status as 状态,
F_AuditStatus as 审批状态
from dbo.T_Warehouse_FactoryAllocationIn
union
select F_ID as ID, ‘取消‘ as 类型, F_AllocationSN as 调拨单号, F_SN as 单号, F_ServiceTime as 业务日期, ‘‘ as 调出工厂, ‘‘ as 调出仓库,
‘‘ as 调入工厂,‘‘ as 调入仓库, F_CreationTime as 创建时间, F_Creator as 创建人, F_Status as 状态,
F_AuditStatus as 审批状态
from dbo.T_Warehouse_FactoryAllocationCancel
) as t
where t.调拨单号= ANY(select * from @sqltable)  --临时表的使用
order by t.调拨单号,t.类型
END

一个复杂的SQL存储过程例子

标签:

人气教程排行