記得以前有個同事問過我這個,說是以前面試的時候碰到的問題,下面我介紹三種方法。
首先我們在這里創建一個測試表添加相應的測試數據。
create table test (id number,name varchar(10));
insert into test values(1,'liufang');
insert into test values(2,'xiaozhang');
insert into test values(3,'dawei');
insert into test values(4,'laotan');
insert into test values(5,'laotan');
insert into test values(6,'laotan');
insert into test values(7,'dawei');
1、根絕name相同 ID不同來的方式來判斷(id必須唯一)
delete from test a where exists (select null from test b where b.name=a.name and b.id>a.id);
2、用rowid 來代替其中的id,比上面的方法更適用,沒有字段唯一限制
delete from test a where exists (select null from test b where b.name=a.name and b.rowid>a.rowid);
3、 通過分析函數根據name 分組生成序號,然后刪除序號大於1 的數據
(注:rder by 2,3根據查詢的第二第三個字段升序排序查詢)
select rowid as rid,name,row_number() over(partition by name order by id) from test order by 2,3;
分析函數會吧對應名稱相同的字段出現的次數記錄下來,把對應次數大於1 的數據刪除即可
分析函數:ROW_NUMBER() OVER (partition by name order by name) 簡單的說row_number()從1開始,為每一條分組記錄返回一個數字,
這里的ROW_NUMBER() OVER (partition by name order by name) 是先把name列升序,再為降序以后的沒條name記錄返回一個序號,
delete from test
where rowid in (select rowid
from (select rowid as rid,
row_number() over(partition by name order by id) as seq
from test)
where seq > 1);