存货核算中的加权平均

SET  QUOTED_IDENTIFIER  ON  
GO
SET  ANSI_NULLS  ON  
GO

ALTER    proc  CaculateProfit_JiaQuanPingJun

as

-- 加权平均
--
创建虚拟表
--
1.计算出所有的进货成本

/*
   drop table #tbl
   drop table #tbl2
*/



declare       @期初数量   int ,
        
@期初单价   decimal ( 12 , 4 )
        
        
set   @期初数量 = 20
        
set   @期初单价 = 200.00


declare       @入库总数量   int ,
        
@入库总成本   decimal ( 12 , 4 ),
        
@入库成本单价   decimal ( 12 , 4 )
        
        
set   @入库总数量 = 0
        
set   @入库总成本 = 0
        
set   @入库成本单价 = 0
        
        
select   @入库总数量 = sum ( isnull (inputNum, 0 )),
            
@入库总成本 = sum ( isnull (inputNum, 0 ) * isnull (inputPrice, 0 ))
            
from  dbo.InvertoryAccouter
        
-- 计算出成本单价
         select   @入库成本单价   =   @入库总成本 / @入库总数量


create   table  #tbl(IODate   datetime   default ( getdate ()),
            InputNum 
int ,
            InputUnitPrice 
decimal ( 12 , 4 ),
            OutputNum 
int ,
            CostUnitPrice 
decimal ( 12 , 4 ),
            SalesUnitPrice 
decimal ( 12 , 4 ),
            Profit 
decimal ( 12 , 4 ))


select  IODate,
    inputNum,
    inputPrice,
    outputNum,
    SalesPrice,
    
case   when  (outputNum  is   not   null  
                
and  
                SalesPrice 
is   not   null )
            
then   @入库成本单价
        
else
             
null
        
    
end  CostUnitPrice
    
into  #tbl2
        
from  dbo.InvertoryAccouter
        
order   by  IODate  asc



insert   into  #tbl
    (IODate,InputNum,InputUnitPrice,
    
-- InputCost,
    OutputNum,SalesUnitPrice,CostUnitPrice)

select   ' 2001-01-31 23:59:59 ' ,
    
@期初数量 ,
    
@期初单价 ,
    
null ,
    
null ,
    
null
    
    
union   all
select   *  
    
from  #tbl2
    
-- select * from #tbl


select     SUM ( isnull (OutputNum, 0 ) *
        (
isnull (SalesUnitPrice, 0 ) - isnull (CostUnitPrice, 0 )))
    
from  #tbl







GO
SET  QUOTED_IDENTIFIER  OFF  
GO
SET  ANSI_NULLS  ON  
GO

转载于:https://www.cnblogs.com/Bruce_H21/archive/2007/08/02/839987.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值