假设我有一个N:N表关系,我在它们之间进行连接,问题是结果中有许多行具有相同的值,并且我希望在一个包含这些行的ids的row中恢复。
实际返回的结果如下所示。
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 我想把它作为
ID_STREET STREET COUNTRY REGION DUPLICATED
---------------------------------------------------------------
1 street-1 country-1 region-1 1,2
3 street-2 country-2 region-2 3表定义如下所示
------------------------- --------------------------
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 发布于 2013-10-19 01:37:42
在oracle上,聚合LISTAGG函数可以对按其他列分组的列执行字符串连接。
http://docs.oracle.com/cd/E11882_01/server.112/e10592/functions089.htm
根据我从你的表格中收集到的信息,如果我们对你的第一组结果做了这样的处理
SELECT MIN(ID_STREET), STREET, COUNTRY, REGION,
LISTAGG(ID_STREET, ',') WITHIN GROUP (ORDER BY STREET) AS DUPLICATED
FROM MYTABLE
GROUP BY STREET,COUNTRY,REGION我们最终会得到你的第二个。我需要看到原始表,以显示一个查询,它将工作,以做你想做的事情。
https://stackoverflow.com/questions/19455461
复制相似问题