SQL函数设计之临时表的使用

<script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
 

if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[GETALL]') and xtype in (N'FN', N'IF', N'TF'))

drop function [dbo].[GETALL]

GO

--根据起始时间选择设定量、实出量、地面实出量以及出现0的情况,以查看故障信息

CREATE FUNCTION GETALL(@dateStart datetime,@dateEnd datetime)

RETURNS @Result TABLE(ENo int,PlanTotal int,FactTotal int,FactOutTotal int,FactZero int,FactOutZero int) 

AS

BEGIN

DECLARE @Plan TABLE(ENo int ,PlanTotal int )

DECLARE @Fact TABLE(ENo int,FactTotal int,FactOutTotal int)

DECLARE @FactZero TABLE(ENo int,FactZero int)

DECLARE @FactOutZero TABLE(ENo int,FactOutZero int)

INSERT @Plan

SELECT Electrobath_No,sum(Al_P_Plan) AS planTotal

FROM Al_Product2005 as a

WHERE (C_date between @dateStart and @dateEnd) and (Al_Status<>'0') and (Al_P_Fact<>'0')

and

(

NOT EXISTS

(

SELECT *

FROM Al_Product2005 AS b

WHERE

(a.Al_F_Count < b.Al_F_Count) AND (a.Electrobath_No = b.Electrobath_No)

AND (a.Al_P_count = b.Al_P_count) AND (a.C_Date = b.C_Date) AND (Al_Status <> 0)

)

)

GROUP BY Electrobath_No

INSERT @Fact

SELECT DISTINCT Electrobath_No,sum(Al_P_Fact) as factTotal,sum(Al_P_FactOut) as factOutTotal

FROM Al_Product2005

WHERE (C_Date between @dateStart and @dateEnd)

GROUP BY Electrobath_No

INSERT @FactZero

SELECT Electrobath_No,count(Al_P_Fact) AS FactZero

FROM Al_Product2005 

WHERE (C_Date between @dateStart and @dateEnd) and (Al_P_Fact='0')

GROUP BY Electrobath_No

INSERT @FactOutZero

SELECT Electrobath_No,count(Al_P_FactOut) as FactOutZero

FROM Al_Product2005 

WHERE (C_Date between @dateStart and @dateEnd) and (Al_P_FactOut='0')

GROUP BY Electrobath_No

INSERT @Result

SELECT a.ENo,PlanTotal,FactTotal,b.FactOutTotal,c.FactZero,d.FactOutZero

FROM @Plan a,@Fact b,@FactZero c,@FactOutZero d

RETURN

END <script type="text/javascript"> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>

<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值