人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

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

發(fā)布日期:2022-01-17 08:16 | 文章來源:源碼之家

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

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

到支付訂單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
       )
   /*核銷金額為負數(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í)有所幫助。

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部