如何計算多個訂單的核銷金額
本文介紹了計算多個訂單的核銷金額的全部過程,運行數(shù)據(jù)庫環(huán)境:SQL SERVER 2005,下面跟大家分享一下。
下圖是一張訂單明細表,現(xiàn)有金額要1700,根據(jù)訂單單號的順序依次對訂單金額進行核銷。
到支付訂單6時,支付金額不足,只能支付200,后面訂單的核銷金額為0。
1.基礎數(shù)據(jù)準備
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);
解題思路如下:
先計算出在每個訂單之前總共要核銷的金額數(shù),然后加上本次將要核銷的訂單金額,跟1700比較,
如果總和小于等于1700,那么,這個訂單的訂單金額可以全部核銷,否則,只能核銷部分,
即1700-本訂單之前的所有訂單金額之和。
;WITH x1 AS ( SELECT t1.id , t1.dingdan , t1.sale , ( SELECT ISNULL(SUM(t2.sale), 0) FROM #t t2 WHERE t2.id < t1.id ) AS curr_sale_sum--本訂單之前的所有訂單金額 FROM #t t1 ),/*計算出核銷金額*/ x2 AS ( SELECT id , dingdan , sale , CASE WHEN curr_sale_sum + sale <= 1700 THEN sale ELSE 1700 - curr_sale_sum END AS new_sale FROM x1 ) /*核銷金額為負數(shù),則變更為0*/ SELECT id AS 序號, dingdan 訂單, sale 訂單金額, CASE WHEN new_sale < 0 THEN 0 ELSE new_sale END AS 核銷金額 FROM x2
由于不能用分析函數(shù)來解題,只好用標量子查詢實現(xiàn)相同的效果。當然,提供的數(shù)據(jù)有一定的局限性,
如果序號不是連續(xù)的,直接套用我的SQL無法解決,需要自己生成一個連續(xù)的序號。
結果如下:
以上就是關于計算多個訂單的核銷金額的全部解題思路,希望對大家的學習有所幫助。
相關文章
SQL2005重新生成索引的的存儲過程 sp_rebuild_index
本文分享了一個筆者自己整理的存儲過程,幫助技術人員快速的重新生成數(shù)據(jù)庫的索引,以減輕重復的工作,有需要的朋友,可以參考一下。2016-03-03SQL Server創(chuàng)建維護計劃失?。⊿QL Server:14234 錯誤)的解決方法
這篇文章主要介紹了SQL Server創(chuàng)建維護計劃失敗(SQL Server:14234 錯誤)的解決方法,最后使用SQLServer2005 安裝向?qū)Ы鉀Q問題,需要的朋友可以參考下2014-08-08SQL 2005使用專用管理員連接(DAC)的技巧及修改系統(tǒng)表的方法
SQL Server 2005 為管理員提供了一種特殊的診斷連接,以供在無法與服務器建立標準連接時使用。2011-07-07SQL Server 數(shù)據(jù)庫清除日志的方法
SQLSERVER的數(shù)據(jù)庫日志占用很大的空間,下面提供三種方法用于清除無用的數(shù)據(jù)庫日志文件2012-07-07SQL2005利用ROW_NUMBER() OVER實現(xiàn)分頁功能
SQL2005利用ROW_NUMBER() OVER實現(xiàn)分頁功能,需要的朋友可以參考下2012-12-12