论坛贴子:
已有数据:
==========
会计期 物料分类 期初 本期入 本期出 期末
200901 C1 10 1 2 9
200901 C2 10 1 3 8
200902 C1 9 0 2 7
200902 C2 8 1 2 7
查询 200801-200912 的数据,查询结果:
==========
开始会计期 结束会计期 物料分类 期初 本期入 本期出 期末
200901 200902 C1 10 1 4 7
200901 200902 C2 10 2 5 7
注意:
期初,取查询范围内存在的最小会计期的期初
期末,取查询范围内存在的最大会计期的期末
本期入和出,求和
解决方法:
SQL> drop table tmp;
表已删除。
SQL> create table tmp(kjq varchar(6),wlfl varchar(2),qc number(2),bql number(2),
bqc number(2),qm number(2));
表已创建。
SQL> insert into tmp values('200901','c1',10,1,2,9);
已创建 1 行。
SQL> insert into tmp values('200901','c2',10,1,3,8);
已创建 1 行。
SQL> insert into tmp values('200902','c1',9,0,2,7);
已创建 1 行。
SQL> insert into tmp values('200902','c2',8,1,2,7);
已创建 1 行。
SQL> commit;
提交完成。
SQL> select * from tmp;
KJQ WL QC BQL BQC QM
------ -- ---------- ---------- ---------- ----------
200901 c1 10 1 2 9
200901 c2 10 1 3 8
200902 c1 9 0 2 7
200902 c2 8 1 2 7
SQL> select min(kjq) 开始会计期,
2 max(kjq) 结束会计期,
3 wlfl 物料分类,
4 min(qc) keep(dense_rank first order by kjq) 期初,
5 sum(bql) 本期入,
6 sum(bqc) 本期出,
7 max(qm) keep(dense_rank last order by kjq) 期末
8 from tmp
9 group by wlfl;
开始会 结束会 物 期初 本期入 本期出 期末
------ ------ -- ---------- ---------- ---------- ----------
200901 200902 c1 10 1 4 7
200901 200902 c2 10 2 5 7
SQL>
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/21251711/viewspace-1021353/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/21251711/viewspace-1021353/