是否有可能构造SQL来连接列值 多行吗?

举例如下:

表一个

PID
A
B
C

表B

PID   SEQ    Desc

A     1      Have
A     2      a nice
A     3      day.
B     1      Nice Work.
C     1      Yes
C     2      we can 
C     3      do 
C     4      this work!

SQL的输出应该是-

PID   Desc
A     Have a nice day.
B     Nice Work.
C     Yes we can do this work!

所以基本上输出表的Desc列是来自表B的SEQ值的连接?

SQL有什么帮助吗?


当前回答

LISTAGG分析函数是在Oracle 11g Release 2中引入的,这使得聚合字符串变得非常容易。 如果你正在使用11g Release 2,你应该使用这个函数进行字符串聚合。 有关字符串连接的更多信息,请参考下面的url。

http://www.oracle-base.com/articles/misc/StringAggregationTechniques.php

字符串连接

其他回答

有几种方法取决于你有什么版本-请参阅oracle文档关于字符串聚合技术。一个非常常见的方法是使用LISTAGG:

SELECT pid, LISTAGG(Desc, ' ') WITHIN GROUP (ORDER BY seq) AS description
FROM B GROUP BY pid;

然后加入A,挑出你想要的皮皮。

注意:开箱即用,LISTAGG只对VARCHAR2列正确工作。

SQL模型子句:

SQL> select pid
  2       , ltrim(sentence) sentence
  3    from ( select pid
  4                , seq
  5                , sentence
  6             from b
  7            model
  8                  partition by (pid)
  9                  dimension by (seq)
 10                  measures (descr,cast(null as varchar2(100)) as sentence)
 11                  ( sentence[any] order by seq desc
 12                    = descr[cv()] || ' ' || sentence[cv()+1]
 13                  )
 14         )
 15   where seq = 1
 16  /

P SENTENCE
- ---------------------------------------------------------------------------
A Have a nice day
B Nice Work.
C Yes we can do this work!

3 rows selected.

我在这里写过。如果链接到otn线程,您将找到更多内容,包括性能比较。

如果必须排序,LISTAGG将提供最佳性能(00:00:05.85) SELECT pid, LISTAGG(Desc, ' ') WITHIN GROUP (ORDER BY seq) AS description 从B组pid; COLLECT在不需要排序的情况下提供最佳性能(00:00:02.90): SELECT pid, TO_STRING(CAST(COLLECT(Desc) AS varchar2_ntt)) AS val FROM B GROUP BY pid 收集与订购有点慢(00:00:07.08): SELECT pid, TO_STRING(CAST(COLLECT(Desc ORDER BY Desc) AS varchar2_ntt)) AS val FROM B GROUP BY pid

其他所有技术都要慢一些。

在运行select查询之前,运行以下命令:

将服务器设置为6000大小

SELECT XMLAGG(XMLELEMENT(E,SUPLR_SUPLR_ID||',')).EXTRACT('//text()') "SUPPLIER" 
FROM SUPPLIERS;

LISTAGG分析函数是在Oracle 11g Release 2中引入的,这使得聚合字符串变得非常容易。 如果你正在使用11g Release 2,你应该使用这个函数进行字符串聚合。 有关字符串连接的更多信息,请参考下面的url。

http://www.oracle-base.com/articles/misc/StringAggregationTechniques.php

字符串连接