因业务需要,将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 )
一开始的思路是:
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/