人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

oracle數(shù)據(jù)庫去除重復(fù)數(shù)據(jù)常用的方法總結(jié)

發(fā)布日期:2022-07-15 19:25 | 文章來源:CSDN

創(chuàng)建測試數(shù)據(jù)

create table nayi224_180824(col_1 varchar2(10), col_2 varchar2(10), col_3 varchar2(10));
insert into nayi224_180824
select 1, 2, 3 from dual union all
select 1, 2, 3 from dual union all
select 5, 2, 3 from dual union all
select 10, 20, 30 from dual ;
commit;
select*from nayi224_180824;
COL_1COL_2COL_3
123
123
523
102030

針對指定列,查出去重后的結(jié)果集

distinct

select distinct t1.* from nayi224_180824 t1;
COL_1COL_2COL_3
102030
123
523

方法局限性很大,因為它只能對全部查詢的列做去重。如果我想對col_2,col3去重,那我的結(jié)果集中就只能有col_2,col_3列,而不能有col_1列。

select distinct t1.col_2, col_3 from nayi224_180824 t1
COL_2COL_3
23
2030

不過它也是最簡單易懂的寫法。

row_number()

select *
  from (select t1.*,
               row_number() over(partition by t1.col_2, t1.col_3 order by 1) rn
          from nayi224_180824 t1) t1
 where t1.rn = 1
;
COL_1COL_2COL_3RN
1231
1020301

寫法上要麻煩不少,但是有更大的靈活性。

針對指定列,查出所有重復(fù)的行

count having

select *
  from nayi224_180824 t
 where (t.col_2, t.col_3) in (select t1.col_2, t1.col_3
    from nayi224_180824 t1
   group by t1.col_2, t1.col_3
  having count(1) > 1)
COL_1COL_2COL_3
123
123
523

要查兩次表,效率會比較低。不推薦。

count over

select *
  from (select t1.*,
               count(1) over(partition by t1.col_2, t1.col_3) rn
          from nayi224_180824 t1) t1
 where t1.rn > 1
;
COL_1COL_2COL_3RN
1233
1233
5233

只需要查一次表,推薦。

刪除所有重復(fù)的行

delete from nayi224_180824 t
 where t.rowid in (
                   select rid
                     from (select t1.rowid rid,
       count(1) over(partition by t1.col_2, t1.col_3) rn
  from nayi224_180824 t1) t1
                    where t1.rn > 1);

就是上面的語句稍作修改。

刪除重復(fù)數(shù)據(jù)并保留一條

分析函數(shù)法

delete from nayi224_180824 t
 where t.rowid in (select rid
                     from (select t1.rowid rid,
      row_number() over(partition by t1.col_2, t1.col_3 order by 1) rn
 from nayi224_180824 t1) t1
                    where t1.rn > 1);

擁有分析函數(shù)一貫的靈活性高的特點。可以為所欲為的分組,并通過改變orderby從句來達到像”保留最大id“這樣的要求。

group by

delete from nayi224_180824 t
 where t.rowid not in
       (select max(rowid) from nayi224_180824 t1 group by t1.col_2, t1.col_3);

犧牲了一部分靈活性,換來了更高的效率。

總結(jié)

到此這篇關(guān)于oracle數(shù)據(jù)庫去除重復(fù)數(shù)據(jù)常用的文章就介紹到這了,更多相關(guān)oracle去除重復(fù)數(shù)據(jù)內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

香港服務(wù)器租用

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部