用rownum实现分析函数row_number()的功能,即根据表中某一列输出一个唯一编号。
SQL> select * from t;
DOCID NAME CRENO MONEY
---------- ---------- ---------- ----------
20111 0 320000 60000
201203 张红 320233 60116.5
201201 张三 320112 60056
201201 李四 320113 60056.5
201201 王五 320114 60057
201202 周红 320118 60059
201203 刘星 320119 60059.5
---------- ---------- ---------- ----------
20111 0 320000 60000
201203 张红 320233 60116.5
201201 张三 320112 60056
201201 李四 320113 60056.5
201201 王五 320114 60057
201202 周红 320118 60059
201203 刘星 320119 60059.5
已选择7行。
已用时间: 00: 00: 00.02
用row_number()的实现方法如下:
SQL> select t.docid,t.name,t.creno,row_number() over(partition by DOCID order by DOCID) n from t;
DOCID NAME CRENO N
---------- ---------- ---------- ----------
20111 0 320000 1
201201 李四 320113 1
201201 王五 320114 2
201201 张三 320112 3
201202 周红 320118 1
201203 刘星 320119 1
201203 张红 320233 2
---------- ---------- ---------- ----------
20111 0 320000 1
201201 李四 320113 1
201201 王五 320114 2
201201 张三 320112 3
201202 周红 320118 1
201203 刘星 320119 1
201203 张红 320233 2
已选择7行。
已用时间: 00: 00: 00.02
用rownum实现类似上述的功能:
SQL> with t1 as (select rownum rn,t.* from (select * from t order by docid)t),
2 t2 as (select min(t1.rn) mrn,t1.docid from t1 group by t1.docid)
3 select t1.docid,t1.name,t1.creno,(t1.rn-t2.mrn+1) n from t1,t2
4 where t1.docid=t2.docid
5 /
2 t2 as (select min(t1.rn) mrn,t1.docid from t1 group by t1.docid)
3 select t1.docid,t1.name,t1.creno,(t1.rn-t2.mrn+1) n from t1,t2
4 where t1.docid=t2.docid
5 /
DOCID NAME CRENO N
---------- ---------- ---------- ----------
20111 0 320000 1
201201 李四 320113 1
201201 王五 320114 2
201201 张三 320112 3
201202 周红 320118 1
201203 刘星 320119 1
201203 张红 320233 2
---------- ---------- ---------- ----------
20111 0 320000 1
201201 李四 320113 1
201201 王五 320114 2
201201 张三 320112 3
201202 周红 320118 1
201203 刘星 320119 1
201203 张红 320233 2
已选择7行。
已用时间: 00: 00: 00.18
SQL>
SQL>
点评:rownum这一伪劣非常灵活,要懂得灵活应用!
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/26977915/viewspace-733842/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/26977915/viewspace-733842/