如何计算期初和期末数量余额 SQL Server
- 作者: 爱国者I帕克
- 来源: 51数据库
- 2022-12-01
问题描述
我有以下表格结构
TransactionDate Item RecQty IssueQty1-jun-2011 A 10 02-jun-2011 A 15 02011 年 6 月 3 日 A 20 02011 年 6 月 4 日 A 0 202011 年 6 月 4 日 A 0 20
我想要特定日期的结果,即 2-jun-2011
Item Opening RecQty IssueQty BalanceQty10 15 0 25
2011 年 1 月 4 日
Item Opening RecQty IssueQty BalanceQty45 0 40 5
解决方案
我打算至少假设 SQL Server 2005.将来,请使用您需要支持的最低版本指定/标记问题.
>
创建表#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;
推荐阅读
热点文章
检查拆分键盘
0
带有“上一个"的工具栏和“下一个"用于键盘输入AccessoryView
0
Activity 启动时显示软键盘
0
UIWebView 键盘 - 摆脱“上一个/下一个/完成"酒吧
0
在 iOS7 中边缘滑动时,使键盘与 UIView 同步动画
0
我的 iOS 应用程序中的键盘在 iPhone 6 上太高了.如何在 XCode 中调整键盘的分辨率?
0
android:inputType="textEmailAddress";- '@' 键和 '.com' 键?
0
禁用 iPhone 中键盘的方向
0
Android 2.3 模拟器上的印地语键盘问题
0
keyDown 没有被调用
0
