用户登录
还没有账号?立即注册
用户注册
点击换图
投稿取消
文章分类:
还能输入300字

上传中....

热门文章更多>>
标签更多>>
专题更多>>
最新文章更多>>

如何计算期初和期末数量余额 SQL Server

>

创建表#x(交易日期 **ALLDATETIME,项目 CHAR(1), RecQty INT, IssueQty INT);插入 #x 选择 '20110601','A',10,0UNION ALL SELECT '20110602','A',15,0UNION ALL SELECT '20110603','A',20,0UNION ALL SELECT '20110604','A',0,20UNION ALL SELECT '20110604','A',0,20;声明 @StartDate **ALLDATETIME = '20110601',@Date **ALLDATETIME = '20110602';WITH x(Item, prevR, prevI, curR, curI) AS(选择物品,SUM(CASE WHEN TransactionDate < @Date THEN RecQty ELSE 0 END),SUM(CASE WHEN TransactionDate < @Date THEN IssueQty ELSE 0 END),SUM(CASE WHEN TransactionDate = @Date THEN RecQty ELSE 0 END),SUM(CASE WHEN TransactionDate = @Date THEN IssueQty ELSE 0 END)FROM #x WHERE TransactionDate BETWEEN @StartDate 和 @Date按项目分组)选择物品,开场 = prevR - prevI,RecQty = curR,IssueQty = curI,BalanceQty = (prevR - prevI) + (curR - curI)从 x;删除表#x;

I have the following table strucature

TransactionDate   Item  RecQty  IssueQty

1-jun-2011         A      10      0
2-jun-2011         A      15      0
3-jun-2011         A      20      0
4-jun-2011         A       0     20
4-jun-2011         A       0     20

And I want the result on specific Date i.e 2-jun-2011

 Item    Opening     RecQty  IssueQty  BalanceQty
  A       10            15     0         25

And on 4-Jan-2011

 Item    Opening     RecQty  IssueQty  BalanceQty
  A       45            0     40         5

解决方案

I'm going to assume at least SQL Server 2005. In the future, please specify/tag the question with the minimum version you need to support.

CREATE TABLE #x
(
    TransactionDate **ALLDATETIME,
    Item CHAR(1), RecQty INT, IssueQty INT
);

INSERT #x SELECT '20110601','A',10,0
UNION ALL SELECT '20110602','A',15,0
UNION ALL SELECT '20110603','A',20,0
UNION ALL SELECT '20110604','A',0,20
UNION ALL SELECT '20110604','A',0,20;

DECLARE @StartDate **ALLDATETIME = '20110601', 
        @Date      **ALLDATETIME = '20110602';

WITH x(Item, prevR, prevI, curR, curI) AS
(
    SELECT 
        Item,
        SUM(CASE WHEN TransactionDate < @Date THEN RecQty ELSE 0 END),
        SUM(CASE WHEN TransactionDate < @Date THEN IssueQty ELSE 0 END),
        SUM(CASE WHEN TransactionDate = @Date THEN RecQty ELSE 0 END),
        SUM(CASE WHEN TransactionDate = @Date THEN IssueQty ELSE 0 END)
    FROM #x WHERE TransactionDate BETWEEN @StartDate AND @Date
    GROUP BY Item
)
SELECT 
    Item,
    Opening = prevR - prevI,
    RecQty = curR,
    IssueQty = curI,
    BalanceQty = (prevR - prevI) + (curR - curI)
FROM x;

DROP TABLE #x;