首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从聚合文本字段中解析和删除重复项

如何从聚合文本字段中解析和删除重复项
EN

Stack Overflow用户
提问于 2016-07-20 12:37:54
回答 2查看 112关注 0票数 0

我有一个列,其值如下

代码语言:javascript
复制
select chipset_name from chipset

    chipset_name
    "Chip A,Chip B"
    "Chip A"
    "Chip F"
    "DSOG K"
    "FROW 01 33"
    "Chip F,DSOG K"
    ...

我想将它聚合到一行,而不重复,但是如果我使用string_agg(distinct..)我有复印机

代码语言:javascript
复制
select string_agg(distinct chipset_labels,',')from chipset
----------
Chip A,Chip B,**Chip A**,Chip F,DSOG K,FROW 01 33,Chip F,**DSOG K**

如何解析和删除重复项?

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-07-20 12:48:09

函数string_to_array(chipset_name, ',')将将名称转换为数组。然后对它们进行unnest并只选择不同的值。

代码语言:javascript
复制
select distinct token
from 
    chipset, 
    unnest(string_to_array(chipset_name, ',')) token

   token    
------------
 Chip A
 Chip B
 Chip F
 DSOG K
 FROW 01 33
(5 rows)        
票数 2
EN

Stack Overflow用户

发布于 2016-07-20 12:53:55

regexp_split_to_table不需要取消嵌套:

代码语言:javascript
复制
select string_agg(distinct cl, ',')
from 
    chipset, 
    regexp_split_to_table(chipset_labels, ',') cl(cl)
;
               string_agg               
----------------------------------------
 Chip A,Chip B,Chip F,DSOG K,FROW 01 33
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38481535

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档