主頁(yè) > 知識(shí)庫(kù) > 如何計(jì)算多個(gè)訂單的核銷金額

如何計(jì)算多個(gè)訂單的核銷金額

熱門標(biāo)簽:舞鋼市地圖標(biāo)注app 電銷機(jī)器人虛擬號(hào)碼 九鹿林外呼系統(tǒng)怎么收費(fèi) 滄州營(yíng)銷外呼系統(tǒng)軟件 海南自動(dòng)外呼系統(tǒng)價(jià)格 創(chuàng)業(yè)電銷機(jī)器人 松原導(dǎo)航地圖標(biāo)注 浙江地圖標(biāo)注 沈陽(yáng)智能外呼系統(tǒng)代理

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

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

到支付訂單6時(shí),支付金額不足,只能支付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);

解題思路如下:

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

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

即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
       ),/*計(jì)算出核銷金額*/
    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 序號(hào),
      dingdan 訂單,
      sale 訂單金額,
      CASE WHEN new_sale  0 THEN 0
         ELSE new_sale
      END AS 核銷金額
  FROM  x2

由于不能用分析函數(shù)來(lái)解題,只好用標(biāo)量子查詢實(shí)現(xiàn)相同的效果。當(dāng)然,提供的數(shù)據(jù)有一定的局限性,

如果序號(hào)不是連續(xù)的,直接套用我的SQL無(wú)法解決,需要自己生成一個(gè)連續(xù)的序號(hào)。

結(jié)果如下:

以上就是關(guān)于計(jì)算多個(gè)訂單的核銷金額的全部解題思路,希望對(duì)大家的學(xué)習(xí)有所幫助。

您可能感興趣的文章:
  • 通過SQLSERVER重啟SQLSERVER服務(wù)和計(jì)算機(jī)的方法
  • 利用php+mysql來(lái)做一個(gè)功能強(qiáng)大的在線計(jì)算器
  • 在php和MySql中計(jì)算時(shí)間差的方法
  • mysql 字符串長(zhǎng)度計(jì)算實(shí)現(xiàn)代碼(gb2312+utf8)
  • SQL2005CLR函數(shù)擴(kuò)展-深入環(huán)比計(jì)算的詳解
  • SQLSERVER 根據(jù)地圖經(jīng)緯度計(jì)算距離差示例
  • 用sql實(shí)現(xiàn)18位身份證校驗(yàn)代碼分享 身份證校驗(yàn)位計(jì)算
  • SQL計(jì)算字符串中最大的遞增子序列的方法
  • SQL語(yǔ)句計(jì)算兩個(gè)日期之間有多少個(gè)工作日的方法

標(biāo)簽:咸寧 臺(tái)灣 公主嶺 ???/a> 商洛 西藏 寶雞 日喀則

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何計(jì)算多個(gè)訂單的核銷金額》,本文關(guān)鍵詞  如何,計(jì)算,多個(gè),訂單,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何計(jì)算多個(gè)訂單的核銷金額》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于如何計(jì)算多個(gè)訂單的核銷金額的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章