oracle中刪除表中某欄位出現重複的元素 保留其中一條

來源:互聯網
上載者:User

標籤:

記得以前有個同事問過我這個,說是以前面試的時候碰到的問題,下面我介紹三種方法。

首先我們在這裡建立一個測試表添加相應的測試資料。

 
  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);
  

  

oracle中刪除表中某欄位出現重複的元素 保留其中一條

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.