首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle合并单行中的列值

Oracle合并单行中的列值
EN

Stack Overflow用户
提问于 2013-10-19 01:18:10
回答 1查看 4.8K关注 0票数 0

假设我有一个N:N表关系,我在它们之间进行连接,问题是结果中有许多行具有相同的值,并且我希望在一个包含这些行的idsrow中恢复。

实际返回的结果如下所示。

代码语言:javascript
复制
    ID_STREET     STREET      COUNTRY       REGION    
    ------------------------------------------------
    1             street-1    country-1     region-1     
    2             street-1    country-1     region-1
    3             street-2    country-2     region-2  

我想把它作为

代码语言:javascript
复制
        ID_STREET     STREET      COUNTRY       REGION   DUPLICATED 
    ---------------------------------------------------------------
    1             street-1    country-1     region-1     1,2
    3             street-2    country-2     region-2     3

表定义如下所示

代码语言:javascript
复制
-------------------------         --------------------------
        STREET                            COUNTRY
-------------------------         --------------------------
ID   NUMBER NOT NULL              ID   NUMBER NOT NULL
NAME VARCHAR2(45) NOT NULL        NAME VARCHAR2(45) NOT NULL
ID_COUNTRY NUMBER NOT NULL         ID_REGION NUMBER NOT NULL
...other fields                   ...other fields

-------------------------         
        REGION                            
-------------------------         
ID   NUMBER NOT NULL              
NAME VARCHAR2(45) NOT NULL        
...other fields    
EN

回答 1

Stack Overflow用户

发布于 2013-10-19 01:37:42

在oracle上,聚合LISTAGG函数可以对按其他列分组的列执行字符串连接。

http://docs.oracle.com/cd/E11882_01/server.112/e10592/functions089.htm

根据我从你的表格中收集到的信息,如果我们对你的第一组结果做了这样的处理

代码语言:javascript
复制
SELECT MIN(ID_STREET), STREET, COUNTRY, REGION, 
       LISTAGG(ID_STREET, ',') WITHIN GROUP (ORDER BY STREET) AS DUPLICATED
  FROM MYTABLE
GROUP BY STREET,COUNTRY,REGION

我们最终会得到你的第二个。我需要看到原始表,以显示一个查询,它将工作,以做你想做的事情。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19455461

复制
相关文章

相似问题

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