Oracle 分组排序函数 RANK() DENSE_RANK ( )

因业务需要,将A表中的数据按字段C分组,并对重复数据排序。将处理后的数据插入表D。D表结构比A表多一个排序字段。
一开始的思路是:
1:CURSOR cur is select c,count(*) con from  A group by C having count(*) >1;
2:for i in 1..cn
        insert into d select 。。。。。。
但是,问题也存在。假设某条记录有3条重复,那么以上面的方法处理,插入新表中的数据虽有3条,但完全就是完全相同的一条。。。汗。。
之后,经同事启发,O记有自己的函数。。Love U O

该函数即为:RANK ( ) OVER ( [query_partition_clause] order_by_clause )    OR  DENSE_RANK ( ) OVER ( [query_partition_clause] order_by_clause )

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29143715/viewspace-1767500/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29143715/viewspace-1767500/

你可能感兴趣的:(Oracle 分组排序函数 RANK() DENSE_RANK ( ))