+ -
当前位置:首页 → 问答吧 → 谁能帮忙写出这个SQL脚本,需要判断拆解原数据的日期或份数,得出结果。详细内容如下:

谁能帮忙写出这个SQL脚本,需要判断拆解原数据的日期或份数,得出结果。详细内容如下:

时间:2011-12-15

来源:互联网

原数据:
id,类型,单号,开始日期,截止日期,份数,原ID
1 订单 101 2012-1-1 2012-12-31 10 Null
2 转出 101 2012-3-1 2012-12-31 -1 1
3 转入 101 2012-3-1 2012-12-31 1 1
4 转出 101 2012-4-1 2012-12-31 -1 3
5 转入 101 2012-4-1 2012-12-31 1 3
6 转出 101 2012-1-1 2012-12-31 -1 1
7 转入 101 2012-1-1 2012-12-31 1 1
......
8 订单 102 2012-1-1 2012-12-31 10 Null
9 转出 102 2012-1-1 2012-12-31 -5 8
10 转入 102 2012-1-1 2012-12-31 5 8
11 转出 102 2012-1-1 2012-12-31 -2 10
12 转入 102 2012-1-1 2012-12-31 2 10
......

原数据说明:
1、id:唯一标识、
2、原ID:记录在某个ID基础之上进行的“转入、转出”动作。


需要得到结果如下表

ID,类型,单号,开始日期,截止日期,份数
1 投递 101 2012-1-1 2012-12-31 8
1 投递 101 2012-1-1 2012-2-28 1
1 投递 101 2012-3-1 2012-3-31 1
1 投递 101 2012-4-1 2012-12-31 1
1 投递 101 2012-1-1 2012-12-31 1
......
8 投递 102 2012-1-1 2012-12-31 5
8 投递 102 2012-1-1 2012-12-31 3
8 投递 102 2012-1-1 2012-12-31 2
......
结果说明:每单多投递行的日期、份数 等于 原数据 类型为订单的日期、份数。

作者: QQ1806724   发布时间: 2011-12-15

得出结果补冲:
用原数据类型为“转出”且“原ID等于ID的”逐行参与计算,即转入1份,类型为“订单”的则减少1份,如果转入的时间与类型“订单”的时间不等,则根据转入的时间拆解为多行。

作者: QQ1806724   发布时间: 2011-12-15