国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

如何計算多個訂單的核銷金額

2024-08-31 01:03:07
字體:
來源:轉載
供稿:網友

本文介紹了計算多個訂單的核銷金額的全部過程,運行數據庫環境:SQL SERVER 2005,下面跟大家分享一下。

下圖是一張訂單明細表,現有金額要1700,根據訂單單號的順序依次對訂單金額進行核銷。

到支付訂單6時,支付金額不足,只能支付200,后面訂單的核銷金額為0。

如何計算多個訂單的核銷金額

1.基礎數據準備

CREATE TABLE #t ( id INT ,dingdan VARCHAR(20),sale MONEY)INSERT INTO #t VALUES (1,'a',100);INSERT INTO #t VALUES (2,'b',200); INSERT INTO #t VALUES (3,'c',300); INSERT INTO #t VALUES (4,'d',400); INSERT INTO #t VALUES (5,'e',500); INSERT INTO #t VALUES (6,'f',600); INSERT INTO #t VALUES (7,'g',700);INSERT INTO #t VALUES (8,'h',800);INSERT INTO #t VALUES (9,'i',900);INSERT INTO #t VALUES (10,'j',1000);

解題思路如下:

先計算出在每個訂單之前總共要核銷的金額數,然后加上本次將要核銷的訂單金額,跟1700比較,

如果總和小于等于1700,那么,這個訂單的訂單金額可以全部核銷,否則,只能核銷部分,

即1700-本訂單之前的所有訂單金額之和。

;WITH x1AS ( SELECT t1.id ,t1.dingdan ,t1.sale ,( SELECT ISNULL(SUM(t2.sale), 0)FROM #t t2WHERE t2.id < t1.id) AS curr_sale_sum--本訂單之前的所有訂單金額FROM #t t1),/*計算出核銷金額*/x2AS ( SELECT id ,dingdan ,sale ,CASE WHEN curr_sale_sum + sale <= 1700 THEN saleELSE 1700 - curr_sale_sumEND AS new_saleFROM x1)/*核銷金額為負數,則變更為0*/ SELECT id AS 序號,dingdan 訂單,sale 訂單金額,CASE WHEN new_sale < 0 THEN 0ELSE new_saleEND AS 核銷金額 FROM x2

由于不能用分析函數來解題,只好用標量子查詢實現相同的效果。當然,提供的數據有一定的局限性,

如果序號不是連續的,直接套用我的SQL無法解決,需要自己生成一個連續的序號。

結果如下:

如何計算多個訂單的核銷金額

以上就是關于計算多個訂單的核銷金額的全部解題思路,希望對大家的學習有所幫助。

您可能感興趣的文章:

Tags:SQL2005 計算核銷金額

上一篇:SQL server 2005中設置自動編號字段的方法

下一篇:下面沒有鏈接了

相關文章

文章評論

最 近 更 新

熱 點 排 行

關于我們 - 廣告合作 - 聯系我們 - 免責聲明 - 網站地圖 - 投訴建議 - 在線投稿

CopyRight © 2006-2015 腳本之家 JB51.Net , All Rights Reserved

如何計算多個訂單的核銷金額

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通化市| 杨浦区| 乐陵市| 上虞市| 县级市| 抚州市| 东兴市| 潞城市| 邵武市| 安顺市| 高陵县| 焉耆| 民乐县| 蓬溪县| 巫山县| 界首市| 繁峙县| 洛川县| 上饶市| 镇坪县| 隆回县| 晋中市| 苏州市| 绥德县| 宝鸡市| 福海县| 和静县| 辛集市| 敦化市| 泉州市| 盐城市| 金昌市| 安阳市| 枣阳市| 七台河市| 云南省| 新建县| 广水市| 西畴县| 多伦县| 尚志市|