亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Oracle?listagg去重distinct的三種方式總結(jié)

 更新時(shí)間:2022年11月18日 11:17:49   作者:每天都要進(jìn)步一點(diǎn)點(diǎn)  
這篇文章主要介紹了Oracle?listagg去重distinct的三種方式總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

一、簡(jiǎn)介

最近在工作中,在寫(xiě)oracle統(tǒng)計(jì)查詢(xún)的時(shí)候,遇到listagg聚合函數(shù)分組聚合之后出現(xiàn)很多重復(fù)數(shù)據(jù)的問(wèn)題,于是研究了一下listagg去重的幾種方法

以下通過(guò)實(shí)例講解三種實(shí)現(xiàn)listagg去重的方法。

二、方法

首先還原listagg聚合之后出現(xiàn)重復(fù)數(shù)據(jù)的現(xiàn)象,打開(kāi)plsql,執(zhí)行如下sql:

select t.department_name depname,
       t.department_key,
       listagg(t.class_key, ',') within group(order by t.class_key) as class_keys
  from V_YDXG_TEACHER_KNSRDGL t
 where 1 = 1
 group by t.department_key, t.department_name

運(yùn)行結(jié)果:

如圖,listagg聚合之后很多重復(fù)數(shù)據(jù),下面講解如何解決重復(fù)數(shù)據(jù)問(wèn)題。

【a】 第一種方法

使用wm_concat() + distinct去重聚合

--第一種方法: 使用wm_concat() + distinct去重聚合
select t.department_name depname,
       t.department_key,
       wm_concat(distinct t.class_key) as class_keys
  from V_YDXG_TEACHER_KNSRDGL t
 where 1 = 1
 group by t.department_key, t.department_name

如上圖,listagg聚合之后沒(méi)有出現(xiàn)重復(fù)數(shù)據(jù)了。oracle官方不太推薦使用wm_concat()來(lái)進(jìn)行聚合,能盡量使用listagg就使用listagg。

【b】第二種方法

使用正則替換方式去重(僅適用于oracle字符串大小比較小的情況)

--第二種方法:使用正則替換方式去重(僅適用于oracle字符串大小比較小的情況)
select t.department_name depname,
       t.department_key,
       regexp_replace(listagg(t.class_key, ',') within
                      group(order by t.class_key),
                      '([^,]+)(,\1)*(,|$)',
                      '\1\3') as class_keys
  from V_YDXG_TEACHER_KNSRDGL t
 group by t.department_key, t.department_name;

這種方式處理listagg去重問(wèn)題如果拼接的字符串太長(zhǎng)會(huì)報(bào)oracle超過(guò)最大長(zhǎng)度的錯(cuò)誤,只適用于數(shù)據(jù)量比較小的場(chǎng)景。

【c】第三種方法

先去重,再聚合(推薦使用)

--第三種方法:先去重,再聚合
select t.department_name depname,
       t.department_key,
       listagg(t.class_key, ',') within group(order by t.class_key) as class_keys
  from (select distinct s.class_key, s.department_key, s.department_name
          from V_YDXG_TEACHER_KNSRDGL s) t
 group by t.department_key, t.department_name
 
--或者
select s.department_key,
       s.department_name,
       listagg(s.class_key, ',') within group(order by s.class_key) as class_keys
  from (select t.department_key,
               t.department_name,
               t.class_key,
               row_number() over(partition by t.department_key, t.department_name, t.class_key order by t.department_key, t.department_name) as rn
          from V_YDXG_TEACHER_KNSRDGL t
         order by t.department_key, t.department_name, t.class_key) s
 where rn = 1
 group by s.department_key, s.department_name;
 

推薦使用這種方式,先把重復(fù)數(shù)據(jù)去重之后再進(jìn)行聚合處理。

三、總結(jié)

以上就是關(guān)于listagg聚合函數(shù)去重的三種處理方法的總結(jié),本文僅僅是筆者的一些總結(jié)和見(jiàn)解,僅供大家學(xué)習(xí)參考,希望能對(duì)大家有所幫助。也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論