在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

数据库中如何使用计算列实现移动加权平均算法

93次阅读
没有评论

共计 2129 个字符,预计需要花费 6 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关数据库中如何使用计算列实现移动加权平均算法的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

代码如下:

if OBJECT_ID(tb) is not null drop table tb 
if OBJECT_ID(TEMP) is not null drop table TEMP 
if OBJECT_ID(FUN_NOWPRICE) is not null drop FUNCTION FUN_NOWPRICE 
if OBJECT_ID(FUN_NOWQTY) is not null drop FUNCTION FUN_NOWQTY 
go 
create table tb( 
id INT 
,Date1 datetime 
,ctype varchar(10) 
,qnt float 
,pri float 
) 
--qnt  数量  
--pri  单价  
insert tb 
select 0, 2009-1-1 ,  进货 , 10, 100 union all 
select 1, 2009-1-1 ,  进货 , 50, 120 union all 
select 2, 2009-1-2 ,  出货 , 30, 150 union all 
select 3, 2009-1-3 ,  进货 , 40, 130 union all 
select 4, 2009-1-3 ,  出货 , 25, 160 
GO 
--  我要算成本价, 按移动加权平均  
/* 
1 进货以后的成本价 c1=(10*100+50*120)/(10+50) 
2 出货以后的成本价 c2=((10+50)*c1-30*c1)/((10+50)-30)=C2 
-- 也就是说出货的时候价格不变  
3 进货以后的成本价 c3=(((10+50)-30)*c2+40*130)/((10+50)-30+40) 
-- 也就是说进货的时候单价更新为(当前库存的总价值 + 库总价值)/ 入库后总数量  
以此类推... 
*/ 
-- 想了半天,觉得只能用循环、递归、游标实现,因为出库时的价格是根据之前的记录算出来的。 
-- 也许有经典的算法,谁知道的麻烦教教我或者发个链接。 
-- 这个 FUNCTION 就是变相实现递归的  
CREATE FUNCTION FUN_NOWPRICE(@ID INT) 
RETURNS NUMERIC(19,6) 
AS 
BEGIN 
RETURN (SELECT ISNULL(NOWPRICE,0) FROM 
(SELECT MAX(NOWPRICE)  NOWPRICE  FROM TEMP T1 WHERE ID @ID AND 
NOT EXISTS(SELECT 1 FROM TEMP WHERE ID T1.ID AND ID @ID)) 
T) 
END 
GO 
-- 这个 FUNCTION 是为了计算方便  
CREATE FUNCTION FUN_NOWQTY(@ID INT) 
RETURNS NUMERIC(19,6) 
AS 
BEGIN 
RETURN (SELECT ISNULL(SUM(CASE CTYPE WHEN  进货  THEN QNT ELSE 0-QNT END),0) FROM TEMP WHERE ID @ID) 
END 
GO 
-- 建一个临时表,包含原表参与运算的全部字段  
create table TEMP( 
id INT 
,Date1 datetime 
,ctype varchar(10) 
,qnt float 
,pri float 
,NOWPRICE AS 
CASE ctype 
WHEN  出货  THEN DBO.FUN_NOWPRICE(ID) 
ELSE (DBO.FUN_NOWPRICE(ID)*DBO.FUN_NOWQTY(ID)+QNT*PRI)/(DBO.FUN_NOWQTY(ID)+QNT) 
END) 
INSERT INTO TEMP 
SELECT * FROM TB 
ORDER BY DATE1 ASC,ID ASC 
SELECT * FROM TEMP 
/* 
0 2009-01-01 00:00:00.000  进货  10 100 100 
1 2009-01-01 00:00:00.000  进货  50 120 116.666666666667 
2 2009-01-02 00:00:00.000  出货  30 150 116.666667 
3 2009-01-03 00:00:00.000  进货  40 130 124.285714428571 
4 2009-01-03 00:00:00.000  出货  25 160 124.285714 
*/

这个写法的不完善处在于它是根据 ID 和日期对记录进行排序的,对于同一天的出入库情况没有处理。实际运用中可以根据 CREATEDATE 等时间标志性字段来进行排序。

感谢各位的阅读!关于“数据库中如何使用计算列实现移动加权平均算法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2129字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 欧美乱码伦视频免费 | 亚洲av蜜桃永久无码精品 | 国产精品手机在线 | 国产亚洲精品美女一区二区 | 熟女人妇交换俱乐部 | 在线看片日本 | 国产精品v片在线观看不卡 国产精品www | 亚洲av永久无码精品网站 | 黄色a级片免费 | 人妻系列av无码专区 | 国产自产一c区 | 免费gav| 亚洲综合精品香蕉久久网 | 日韩欧美在线综合网高清 | 琪琪成人| 亚洲人成网亚洲欧洲无码 | 精品久久久久久久久久久aⅴ | 国产成人久久精品区一区二区 | 亚洲精品国产精品乱码不卞 | av人摸人人人澡人人超碰下载 | 亚洲色图2 | 久热福利视频 | 人人妻人人玩人人澡人人爽 | 国产免费无码av片在线观看不卡 | 欧美性xxxx极品hd欧美风情 | 日韩视频第二页 | 欧美一区二区三区在线观看免费 | 男女边吃奶边做边爱视频 | 亚洲免费视频网址 | 加勒比黑人喝羽月希奶水 | 日日摸夜夜添夜夜免费视 | 精品动漫久久一区二区 | 亚洲视频中文字幕在线观看 | 天天操天天插天天射 | 中字乱码视频 | 狠狠色噜噜狠狠色综合久 | 国产精品对白交换视频 | 极品少妇小泬50pthepon | 国产精品欧美一区二区三区不卡 | 色翁荡息又大又硬又粗又视频图片 | 中文字幕日本乱码仑区在线 |