在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)
原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)
所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。
求教:我有个表有入库时间,有出库时间,我想得到该样式号每月的销售和历史库存
http://bbs.csdn.net/topics/390629790
库结构大概是这样:
货号 样式号 入库时间 出库时间
a001 10 2011-1-10
b002 10 2011-1-10 2011-2-1
c003 10 2012-1-15 2012-2-2
d004 10 2013-2-3 2013-1-5
e005 10 2013-2-3
f006 15 2011-2-15 2011-3-16
g007 15 2011-2-16 2012-3-16
h009 15 2013-1-10
m012 18 2011-1-4
c009 18 2011-4-5 2012-5-6
f008 18 2012-2-19 2013-1-1
e008 18 2013-1-5 2013-2-6
我想得到的结果:
样式号 日期 销售件数 库存件数
10 2011-2 1 1
10 2012-2 1 1
10 2013-1 1 2
15 2011-3 1 0
15 2012-3 1 1
18 2012-5 1 1
18 2013-1 1 1
18 2013-2 1 1
我的解法:
-
if object_id('tb') is not null
-
drop table tb
-
go
-
-
create table tb
-
(
-
[货号] varchar(20),[样式号] int,
-
[入库时间] datetime,
-
[出库时间] datetime
-
)
-
-
insert into tb
-
SELECT 'a001',10,'2011-01-10',null UNION ALL
-
SELECT 'b002',10,'2011-01-10','2011-02-01' UNION ALL
-
SELECT 'c003',10,'2012-01-15','2012-02-02' UNION ALL
-
SELECT 'd004',10,'2013-01-03','2013-01-05' UNION ALL
-
SELECT 'e005',10,'2013-01-03',null UNION ALL
-
SELECT 'f006',15,'2011-02-15','2011-03-16' UNION ALL
-
SELECT 'g007',15,'2011-02-16','2012-03-16' UNION ALL
-
SELECT 'h009',15,'2013-01-10',null UNION ALL
-
SELECT 'm012',18,'2011-01-04',null UNION ALL
-
SELECT 'c009',18,'2011-04-05','2012-05-06' UNION ALL
-
SELECT 'f008',18,'2012-02-19','2013-01-01' UNION ALL
-
SELECT 'e008',18,'2013-01-05','2013-02-06'
-
go
-
-
-
;with t
-
as(
-
select *,
-
row_number() over(partition by 样式号
-
order by 入库时间,出库时间) as rownum
-
from tb
-
),
-
-
tt
-
as
-
(
-
select *,
-
case when 出库时间 is null
-
then (select top 1 出库时间
-
from t t2
-
where t1.样式号 = t2.样式号 and
-
t1.rownum > t2.rownum
-
order by t2.rownum desc)
-
else 出库时间
-
end as prior_row,
-
-
case when 出库时间 is null
-
then (select top 1 出库时间
-
from t t2
-
where t1.样式号 = t2.样式号 and
-
t1.rownum < t2.rownum
-
order by t2.rownum )
-
else 出库时间
-
end as next_row
-
-
from t t1
-
),
-
-
ttt
-
as
-
(
-
select 样式号,
-
convert(varchar(7),isnull(next_row,prior_row),120) as 日期,
-
count(出库时间) 销售件数,
-
count(入库时间) 库存件数,
-
count(入库时间) - count(出库时间) 剩余库存
-
--row_number() over(partition by 样式号
-
--order by convert(varchar(7),isnull(next_row,prior_row),120)) as rownum
-
from tt
-
group by 样式号,
-
convert(varchar(7),isnull(next_row,prior_row),120)
-
-
)
-
-
select t1.样式号,t1.日期,
-
isnull(t1.销售件数,0) as 销售件数 ,
-
-
isnull(t1.库存件数,0) +
-
isnull((select sum(库存件数)-sum(销售件数) as 剩余库存 from ttt t2
-
where t2.样式号 = t1.样式号
-
and t2.日期 < t1.日期
-
),0) -
-
isnull(t1.销售件数,0) as 库存件数
-
-
from ttt t1
-
order by t1.样式号
-
/*
-
样式号 日期 销售件数 库存件数
-
10 2011-02 1 1
-
10 2012-02 1 1
-
10 2013-01 1 2
-
15 2011-03 1 0
-
15 2012-03 1 1
-
18 2012-05 1 1
-
18 2013-01 1 1
-
18 2013-02 1 1
-
*/
在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)的更多相关文章
- 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)
原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)
原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...
- 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)
原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...
- 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)
原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)
原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...
- 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)
原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...
- 在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名)
原文:在论坛中出现的比较难的sql问题:37(动态行转列 某一行数据转为列名) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串)
原文:在论坛中出现的比较难的sql问题:36(动态行转列 解析json格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
随机推荐
- 【Java/Csv/Regex】用正则表达式去劈分带引号的csv文件行,得到想要的行数据
csv文件是用引号分隔的文本行,为了完善内容人们又用引号把每个区块的内容又包了起来,于是形成下面的文件: "1","2","3"," ...
- vector 移除元素
vector中移除“与某值相等”的第一个元素. std::vector<Elem> coll; ... //remove first element with value val std: ...
- 前端速查手册——Note
目录 自定义弹框(模块框) HTML5新增标签 HTML5新增属性 自定义弹框(模块框) HTML <div style="display:none" id="mo ...
- 报错:ModuleNotFoundError: No module named '_ctypes'
报错背景: CentOS 7 Python3.7 安装 setuptools 插件的时候报错. 报错现象: [root@master setuptools-]# python3. setup.py b ...
- PAT 甲级 1146 Topological Order (25 分)(拓扑较简单,保存入度数和出度的节点即可)
1146 Topological Order (25 分) This is a problem given in the Graduate Entrance Exam in 2018: Which ...
- Spring Cloud 如何使用Eureka注册服务 4.2.2
要使用Eureka实现服务发现,需要项目中包含Eureka的服务端发现组件以及客户端发现组件. 搭建Maven父工程 创建一个Maven父工程xcservice-springcloud,并在工程的po ...
- 【翻译】生成 Timestamps / Watermarks
本文翻译自flink官网:https://ci.apache.org/projects/flink/flink-docs-release-1.7/dev/event_timestamps_waterm ...
- Linux脚本检测当前用户是否为root用户
#/bin/bash if [ $UID -ne 0 ]; then echo Non root user. Please run as root. else echo Root user fi
- canvas《砸肉蛋》
计划今年要自己写几个游戏的demo,先从<砸地鼠>这种简单的入手. 游戏思路 卡通化前端组头像 两种状态(快乐&被砸) 游戏时间1分钟 微信接口,分享最终得分 游戏规则 前端组的肉 ...
- 清除 sql server 记住密码
引用:https://www.cnblogs.com/zengbin/p/4307013.html SQL Server 2005 Management Studio %AppData%\Micros ...
