本文介紹了計算多個訂單的核銷金額的全部過程,運行數(shù)據(jù)庫環(huán)境:SQL SERVER 2005,下面跟大家分享一下。
下圖是一張訂單明細(xì)表,現(xiàn)有金額要1700,根據(jù)訂單單號的順序依次對訂單金額進(jìn)行核銷。
到支付訂單6時,支付金額不足,只能支付200,后面訂單的核銷金額為0。
1.基礎(chǔ)數(shù)據(jù)準(zhǔn)備
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
)
/*核銷金額為負(fù)數(shù),則變更為0*/
SELECT id AS 序號,
dingdan 訂單,
sale 訂單金額,
CASE WHEN new_sale 0 THEN 0
ELSE new_sale
END AS 核銷金額
FROM x2
由于不能用分析函數(shù)來解題,只好用標(biāo)量子查詢實現(xiàn)相同的效果。當(dāng)然,提供的數(shù)據(jù)有一定的局限性,
如果序號不是連續(xù)的,直接套用我的SQL無法解決,需要自己生成一個連續(xù)的序號。
結(jié)果如下:
以上就是關(guān)于計算多個訂單的核銷金額的全部解題思路,希望對大家的學(xué)習(xí)有所幫助。
您可能感興趣的文章:- 通過SQLSERVER重啟SQLSERVER服務(wù)和計算機的方法
- 利用php+mysql來做一個功能強大的在線計算器
- 在php和MySql中計算時間差的方法
- mysql 字符串長度計算實現(xiàn)代碼(gb2312+utf8)
- SQL2005CLR函數(shù)擴展-深入環(huán)比計算的詳解
- SQLSERVER 根據(jù)地圖經(jīng)緯度計算距離差示例
- 用sql實現(xiàn)18位身份證校驗代碼分享 身份證校驗位計算
- SQL計算字符串中最大的遞增子序列的方法
- SQL語句計算兩個日期之間有多少個工作日的方法