收藏本站 收藏本站
積木網首頁 - 軟件測試 - 常用手冊 - 站長工具 - 技術社區
首頁 > 數據庫 > mssql2005 > 正文

首頁 - PHP - 數據庫 - 操作系統 - 游戲開發 - JS - Android - MySql - Redis - MongoDB - Win8 - Shell編程 - DOS命令 - jQuery - CSS樣式 - Python - Perl

Access - Oracle - DB2 - SQLServer - MsSql2008 - MsSql2005 - Sqlite - PostgreSQL - node.js - extjs - JavaScript vbs - Powershell - Ruby

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

本文介紹了計算多個訂單的核銷金額的全部過程,運行數據庫環境: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  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
       )
   /*核銷金額為負數,則變更為0*/
  SELECT id AS 序號,
      dingdan 訂單,
      sale 訂單金額,
      CASE WHEN new_sale < 0 THEN 0
         ELSE new_sale
      END AS 核銷金額
  FROM  x2

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

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

結果如下:

查看圖片

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

簡述SQL Server 2005數據庫鏡像相關知識
SQLServer數據庫中,數據庫鏡像是用于提高數據庫可用性的主要軟件解決方案。數據庫鏡像基于每個數據庫實現,并且只適用于使用完整恢復模式的數據

SQL Server 2005 定時執行SQL語句的方法
SQLSERVER2005有定時任務,你可以啟動一下。不過要想更加直觀的控制,直接寫一個程序,定時執行你的存儲過程。1、設置SQLServer代理(SQLServerAgent)服務隨

Sql server 2005安裝時ASP.Net版本注冊要求警告的解決方法
在安裝SQLServer2005時出現ASP.Net版本注冊要求(警告),提示找不到ASP.Net在MicrosoftInternet信息服務(IIS)中的版本注冊信息。首先在確認安裝了IIS,并且安

本周排行

更新排行

強悍的草根IT技術社區,這里應該有您想要的! 友情鏈接:b2b電子商務
Copyright © 2010 Gimoo.Net. All Rights Rreserved  京ICP備05050695號
捕鱼大师辅助软件 一定牛福建快3 体彩6十1奖金多少 加拿大快乐8预测网 股票权重什么意思 浙江11选5前三直遗漏一定牛 免费股票推荐群的目的 pc蛋蛋内部人员qq 广西快乐十分是合法吗 安徽快3分析器 每日股票推荐 博客 江苏快3app官方下载 甘肃快3开奖果49 一分钟11选5 赤赢配资 加拿大快乐8开奖数据 北京快乐8 基本走势