在论坛中出现的比较难的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格式字符串) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
随机推荐
- 微信小程序设置全局请求URL 封装wx.request请求
app.js: App({ //设置全局请求URL globalData:{ URL: 'https://www.oyhdo.com', }, /** * 封装wx.request请求 * metho ...
- (二)SpringMVC+mybatis实践
一.需求 以案例作为驱动 springmvc和mybatis使用一个案例(商品订单管理系统) 功能需求:商品的列表查询 二.环境准备 数据库环境 Java环境 jdk1.8 eclipse sprin ...
- Spring Boot CLI——centos7
Spring Boot是一个命令行工具,用于使用Spring进行快速原型搭建.它允许你运行Groovy脚本,这意味着你可以使用类Java的语法,并且没有那么多的模板代码. 所有版本下载地址这里下载的版 ...
- springboot+jwt完成登录认证
本demo用于测试jwt,通过登录验证通过后,使用jwt生成token,然后在请求header中携带token完成访问用户列表信息. 准备工作: 1. 实体类SysUser.java package ...
- flutter DropdownButton使用
import 'package:flutter/material.dart'; class MyStatefulWidget extends StatefulWidget { MyStatefulWi ...
- Centos7搭建OpenNebula云平台
OpenNebula概述 OpenNebula是专门为云计算打造的开源系统,用户可以使用Xen.KVM.VMware等虚拟化软件一起打造企业云.利用OpenNebula可以轻松构建私有云.混合云.公开 ...
- 异常检测-基于孤立森林算法Isolation-based Anomaly Detection-3-例子
参考:https://scikit-learn.org/stable/auto_examples/ensemble/plot_isolation_forest.html#sphx-glr-auto-e ...
- 深入学习c++--智能指针(二) weak_ptr(打破shared_ptr循环引用)
1. 几种智能指针 1. auto_ptr: c++11中推荐不使用他(放弃) 2. shared_ptr: 拥有共享对象所有权语义的智能指针 3. unique_ptr: 拥有独有对象所有权语义的智 ...
- Qt编写气体安全管理系统12-设备双击
一.前言 在编写这个项目的过程中,有个得到客户夸赞的小功能就是,设备按钮双击,在离线的时候是双击重连设备,在线的时候是双击弹出具体详情界面,回控设备,参数设置等.在modbus设备通信过程中,设定了超 ...
- 安卓 android studio 报错 Unknown host 'jcenter.bintray.com'. You may need to adjust the proxy settings in Gradle.
报错截图: 问题原因:因为build.gradle中jcenter()或者maven()被墙了,所以会出现这种情况. 解决方案:(我的gradle版本是:classpath 'com.android. ...
