在DB2中不象Oracle那样可以借助rowid,rownum等伪列来删除重复的记录,也没有有效的方法可以在一个SQL中直接删除记录.但可以借助row_number() over()语法和视图的方式将重复的记录删除.
下面看一个实际的测试DEMO
方法一:借助视图来实现
SQL> create table zrp (no int);
DB20000I SQL命令成功完成。
SQL> insert into zrp values(1);
DB20000I SQL命令成功完成。
SQL> insert into zrp values(1);
DB20000I SQL命令成功完成。
SQL> insert into zrp values(2);
DB20000I SQL命令成功完成。
SQL> insert into zrp values(2);
DB20000I SQL命令成功完成。
SQL> select * from zrp;
NO
-----------
1
1
2
2
4 条记录已选择。
SQL> create view v_zrp as select no,row_number() over(partition by no) as row_seq from zrp;
DB20000I SQL命令成功完成。
SQL> select * from v_zrp;
NO ROW_SEQ
----------- --------------------
1 1
1 2
2 1
2 2
4 条记录已选择。
SQL> delete from v_zrp where row_seq=2;
DB20000I SQL命令成功完成。
SQL> select * from v_zrp;
NO ROW_SEQ
----------- --------------------
1 1
2 1
2 条记录已选择。
SQL> select * from zrp;
NO
-----------
1
2
2 条记录已选择。
SQL>方法二:借助row_number() 函数来实现D:DB2BIN>db2 -td;
SQL> select * from zrp;
NO
-----------
1
1
2
2
4 条记录已选择。
SQL> delete from (select no,row_number() over(partition by no) as row_seq from zrp) t where t.row_seq>1;
DB20000I SQL命令成功完成。
SQL> select * from zrp;
NO
-----------
1
2
2 条记录已选择。
SQL>
补充资料:
select *,row_number() over(order by productname) as rownumber
from products
--上面是正确的,然后我想的是从这个结果集在取10-20之间的数据,然后我书写如下:
select *,row_number() over(order by productname) as rownumber
from products
where rownumber between 10 and 20
--这样报错.然后又找资料看,找不个例子.然后我照那个例子改进
select* from
(select *,row_number() over(order by productname) as rownumber
from products)
as temp
where rownumber between 10 and 20
--这样就对了.
DB2中删除重复记录的方法
最新推荐文章于 2024-01-09 09:15:45 发布